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PREFACE 


Databases are a crucial part of nearly all computer-based business systems. Some read- 
ers of this book may be considering introducing databases into their routine work. Others 
may have to actually develop real database-based business systems. The database is the 
technology that supports these systems behind the scenes, and its true nature is difficult to 
understand. 

This book is designed so that readers will be able to learn the basics about databases 
through a manga story. At the end of each chapter, practice exercises are provided for con- 
firmation and expanding the knowledge you've obtained. Each chapter is designed so that 
readers can gain an understanding of database technology while confirming how much they 
understand the contents. 

The structure of this book is as follows. 

Chapter 1 describes why we use databases. Why is a database necessary? What kind of 
difficulties will you have if you do not use a database? You will learn the background infor- 
mation that using a database requires. 

Chapter 2 provides basic terminology. You'll learn about various database models and 
other terms relating to databases. 

Chapter 3 explains how to design a database, specifically, a relational database, the 
most common kind. 

Chapter 4 covers SQL, a language used to manage relational databases. Using SQL 
allows you to easily manage your data. 

Chapter 5 explains the structure of the database system. Since a database is a system 
through which many people share data, you will learn how it can do so safely. 

Chapter 6 provides descriptions of database applications. You'll learn how Web-based 
and other types of database systems are used. 

This book was published thanks to the joint efforts of many people: Shoko Azuma for 
cartoons, TREND-PRO for production, and Ohmsha for planning, editing, and marketing. | 
extend my deep gratitude to all those concerned. 

| hope that this book is helpful to all readers. 
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Whac /5 a DataBase? 


DON’T LOOK SO 


PRINCESS RURUNA! 


BUT, I JUST HAVE 
5O MUCH TO DO! 


YOU SHOULD BE 
PLEASED ABOUT 
THIS BUSY SEASON. 


" HERE YOU ARE. 


YOU KNOW THAT OUR 

FRUIT RECORDS ARE 

MANAGED BY FILES 
CREATED BY... 


MERCHANDISE DEPART- 
MENT, THE OVERSEAS 
BUSINESS DEPARTMENT, 
AND THE EXPORT 
DEPARTMENT, 
DON’T YOU? 


THE KINGDOM 


OF KOD— 


"THE COUNTRY 


OF FRUIT” 


THIS YEAR'S 
HARVEST 

SHOULD BE 

BOUNTIFUL! JQ 


BUSINES 
PEPARTMEN 


) 


EXPORT 
DEPARTMEN 


I WISH I COULD 
HANDLE THINGS 
MUCH MORE 
EFFECTIVELY. 


I’M SURE IT IS 
AN EXTREMELY 
EFFICIENT 
SYSTEM. 


NOW, WORK, 
WORK!! 


LA DEE DA LA 


LA DEE DUM! 


I WONDER IF IT |S 
INEFFECTIVE TO MANAGE 7) \w As beret 
ALL THE DATA ON A | \ a 
DEPARTMENTAL BASIS. 


IT WAS SUCH A 
HEADACHE WHEN THE 
PRICE OF APPLES 
WENT UP THE OTHER 
DAY. 


OH, IT’S YOU, 
CAIN. WHAT'S UP? 


I HAVE A 
PRESENT 
FROM THE 


LD 


IF MY PARENTS WERE STILL 
IN THE CASTLE, THIS WOULD 


NOT BE HAPPENING...! DO YOU HAVE 


TO GO? 


CAIN, TAKE 


IT IS ONE OF MY 


IMPORTANT OFFICIAL cain cA 
DUTIES TO TRAVEL RUR 
ABROAD! DURING OUR 
ABSENCE. 


YOU FORCED 
WORK ON ME, J( 
Vcr 


ANP YOU'RE GOING ON A 
TRIP WITHOUT ME. I CAN’T 
BELIEVE IT! 


fit 


THE KING DECIDED 
TO TAKE THAT TRIP 
BECAUSE HE TRUSTS 
YOU, PRINCESS 
RURUNA. 


WELL, 
A PACKAGE... 


THEN, WHAT DID 
HE SEND ME? 


WHAT IS A DATABASE? 5& 


"WE FOUND A BOOK 
ABOUT GROUNDBREAKING 
TECHNOLOGY IN A 
FARAWAY LAND WE 
VISITED. 


THE PERSON WHO GAVE 
US THIS BOOK TOLD US 
THAT THE BOOK DESCRIBES 
A SECRET TECHNOLOGY 
CALLED A DATABASE. 


WE HEAR THAT THE 
DATABASE IS A SYSTEM 
THAT ALLOWS EVERYONE 
TO SHARE, MANAGE, AND 
USE DATA. 


BUT, HOW IT IS USED 
DEPENDS ON WHO READS 
THIS BOOK. 


THE PERSON GAVE THIS 
BOOK TO US BELIEVING 
THAT THE KINGDOM OF 
KOD WOULD USE IT INA 
PEACEFUL MANNER. 


ee WHERE AM I? 


\ 
: \ WHO ARE 
: yOu? 


AND WHO ARE \\ 0 
YOU? ; 


(a 


A GHOST?! 


b ef 
YOU ARE 

IN THE K... . 
K...KOD & ™ 
CASTLE. i ei 


Ww] 2 


Zz FLYING...? ZIP! || 


I’M CAINI—THE 

CLOSE AIDE 

OF PRINCESS . 
RURUNA OF KOD. ,8| AN 


HOW RUDE! 
I’M TICO. 


_  LOQMY 
BUT ONLY THE Pe: 


— 
(ft 


PEOPLE WHO mH 
OPENED THE BOOK Oy) \\ ees 
CAN SEE ME. ats i 
ye \ 


/ a4 
(aS 
NS 
ina 


M1 


THIS BOOK HAS 
SUPERNATURAL 


= om ASN 
os 


POWERS TO HELP 
THE PEOPLE WHO 
OPENED IT USE THE 
KNOWLEDGE... 


YOU CAME 


OUT OF THE IN A PROPER 


MANNER. 


50... YOU'RE 
GOING TO 
HELP US? 


WHAT IS A DATABASE? 9 


WELL, SHE SEEMS 
HARMLESS SO 
FAR... 


ENOUGH ABOUT 
ME! YOU TWO 
OPENED THE BOOK 
TO LEARN ABOUT 
DATABASEG... : OKAY THEN, 


LET'S 
START. 


TO CREATE A 
DATABAGE... 


THIS IS A VERY 
ELEMENTARY 


BUT WHAT IS A 
DATABASE? 


I AM MANAGING 


DON’T KNOW 


WHAT IT IS. VALUES AND 
NUMBERS CUSTOMERS, 
YOU ARE HANDLING eeLATeO TO “USTOMERS 
Vp AUMGEEe. PUNE BY CREATING 
' FILES ON A 
DEPARTMENTAL 


YES, AND I 
HAVE MANY 
PROBLEMG... 


OH, SO YOU'RE 
MANAGING DATA IN AN 
UNCOORDINATED FASHION, 
BY DEPARTMENT. 


THAT MEANS DATA IS 
DUPLICATED IN EACH 
DEPARTMENT, RIGHT? 


WU 
OVERSEAS 
BUSINESS DEPT.| | EXPORT DEPT. 


GOLD (@) IS THE CURRENCY UNIT 
USED IN THE KINGDOM OF KOD, 
RIGHT? 


KOLONE SAYS, 


"IT 1S AN 


EFFICIENT ) 


SYSTEM” ri es AN 


AND EACH 
DEPARTMENT HAS 
SEPARATE DATA. 


SOMETIMES IT 
CAN CREATE 
PROBLEMS. 


JUST LIKE THAT 
CRISIS THE OTHER 
DAY!! 


WHAT IS A DATABASE? 11 


YES, WHEN THE : THE PRICE OF APPLES, 
PRICE OF APPLES WHICH HAD BEEN 1006, 
WENT UP. Ra WENT UP TO 120G, AS I 

: REMEMBER. 


I SENT A RAISE THE Price {AN 
MESSAGE TO EACH TO 1206! ONE DEPARTMENT 


DEPARTMENT TO FORGOT TO CHANGE 
CHANGE THE PRICE THE PRICE. 
TO 1206, ; 
BUT... 


I DIDN'T 
GET YOUR 
MESSAGE... 


;OVERSEAS 
BUSINESS 


APPLE 1006 


PRICE REMAINS THE SAME! 


12 CHAPTER 1 


NOT ONLY THAT... ANOTHER DEPARTMENT 
CHANGED THE PRICE TO 
3006 BY MISTAKE. 


APPLE: 120G APPLE: 100G 


1S THAT 
RIGHT? 


SOMETHING'S 


EXPORT 
DEPT. 


WRONG! 


IT WAS PARTICULARLY 
THE DATA IN HARD FOR CAIN! HE 


RESPECTIVE 
DEPARTMENTS ee ne 


CONFLICTS, 
DOESN'T IT? 
AND CORRECT 
ALL THE 
ERRORS. 


THE PRICE OF 
APPLES IS NOT 
CORRECT... 


NE 
FIX THE PRICE, | 
PLEASE! 


\ \ 
(EJPs 
TIRED... 


WHAT IS A DATABASE? 13 


MY FATHER SAID, “LET'S 
START A FRUIT-PICKING TOUR 
SOMETIME IN THE FUTURE!” 


BUT I FEEL WE ARE 
FAR FROM READY. 


Wp 3 LET'S START A NEW 
EASYGOING. | a BUSINESS USING THE 
YN |. ; = EXISTING SYSTEM. 
HA-HA-HA! 


EVEN IF WE DO START 50...MY OFFICIAL 
A NEW BUSINESS, IT DUTIES WILL NOT 
SEEMS LIKE IT WILL BE BE REDUCED IN_ | 
IMPOSSIBLE TO USE THE | THE SLIGHTEST! 4 
DATA STORED IN THE y 
CURRENT SYSTEM. 


THE DATA 
WOULD BE 
JUMBLED UP... 


WELL, IT SOUNDS YOU WILL BE 
LIKE YOU HAVE TO TORMENTED BY DATA 


MAKE ENTRIES AND MANAGEMENT EVEN IF 


CONFIRMATIONS EACH YOU DO YOUR BEST, 
TIME ANYTHING CHANGES, WON'T YOUP 
AND IT SEEMS TO BE A 
TOUGH JOB. 


IF YOU START A NEW 
BUSINESS, YOU WILL 
HAVE TO CREATE NEW 
FILES FOR THE NEW 
DEPARTMENT. 
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A SYSTEM IN WHICH 
DATA IS SHARED 
BY EVERYONE 
IS CALLED A 
DATABASE. 


IF YOU USED ONE, 
YOU WOULD NOT 
HAVE TO KEEP 
USELESS DATA. 


IT SOUNDS 
LIKE IT |S 
WORTH 
STUDYING, 

DOESN'T IT? ff 


I DO NOT HAVE A 
PHYSICAL BODY, 
SO I CAN'T USE 
COMPUTERS IN THE 
REAL WORLD. 


BUT IN GRATITUDE % 
FOR BRINGING ME 
OUT OF THE BOOK... 


~~ 
YOU MEAN WE CAN HAVE 
A MUCH MORE EFFICIENT 
SYSTEM THAN THE CURRENT 
2 


I WILL TEACH YOU 
EVERYTHING. BUT FOR ME AND 
YOU MUST DO YOUR (<= MY COUNTRY... 
BEST! fan A) 


I'M GOING FOR IT! 


Whavc’s UP IN THE KINGDOM? 


16 CHAPTER 1 


The Kingdom of Kod currently uses a file-based system to manage its data. But it seems 
that the current system has a few problems. What are they, in particular? Let's look at the 
system in detail. 

The Kingdom currently has three departments: the Merchandise Department, the 
Overseas Business Department, and the Export Department. The Merchandise Department 
keeps track of all fruit produced in the country, the Overseas Business Department manages 
the foreign countries that are the Kingdom's business partners, and the Export Department 
keeps records of the amount of fruit the Kingdom exports. 


PRINCESS 
RURUNA 


OVERSEAS 
BUSINESS 
DEPARTMENT 


MERCHANDISE 


EXPORT 
DEPARTMENT 


DEPARTMENT 


a 


DATA IS DUPLICATED 


Princess Ruruna isn’t satisfied with the current system. But why not? Each department 

in the Kingdom manages data independently. For example, the Merchandise Department 
and the Export Department each create files to manage fruit data. Therefore, data is dupli- 
cated needlessly across the departments. Each department must enter the data, store the 
data, then print receipts for confirmation, all of which is a waste. In addition, data trapped in 
one particular department is never shared effectively with the other departments. 


PRINCESS 


Data is duplicated. 
RURUNA 


OVERSEAS 
ee BUSINESS 


DEPT. 


EXPORT 
DEPT. 


But that’s not all. The system also creates problems when someone needs to change 
the data. For example, let’s assume that the price of apples changes. To deal with this, Prin- 
cess Ruruna must notify every department individually that the price of apples has changed. 
Isn’t that inconvenient? 


PRINCESS 
RURUNA 


The Princess must 
send a message to 
each department. 


OVERSEAS 
BUSINESS 
DEPT. 


EXPORT 


MERCHANDISE 
DEPT. DEPT. 


DATA CAN CONFLICT 


lt may seem easy enough to notify each department that the price of apples has changed, 
but it can create a new set of problems. Let’s say that Princess Ruruna does notify the three 
departments that the price of apples has changed. However, the Overseas Business Depart- 
ment may forget to change the price, or the Export Department might change the price to 
300G instead of 120G. These kinds of errors result in conflicting data between departments, 
which causes the content of the file systems to differ from the conditions of the real world. 
What a pain! 


CHANGE THE PRICE 
OF APPLES FROM 
1006 TO 1206. 


PRINCESS 
RURUNA 


ny 


This may cause 
ee | oS a data. 
MERCHANDISE DEPARTMENT OVERSEAS BUSINESS DEPARTMENT EXPORT DEPARTMENT 


Product name : |Product name : |Product name | Unit price 


Melon Melon Melon 


Strawberry : Strawberry : Strawberry 
Apple ‘| Apple ‘| Apple 


Lemon * |Lemon « {Lemon 
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DATA 15 DIFFICULT TO UPDATE 


The current system not only creates conflicting data, but it also makes it difficult to respond 
to changes in business. For example, let’s say that the King wants to launch a new Tourism 
Department. When a tour guide conducts a tour of the orchards and discusses the King- 
dom’s fruit sales, the guide will want to use the most up-to-date sales figures. 

But, unfortunately, the current system does not necessarily allow the departments to 
access each other's data, since the files are kept independently. To manage a new tourism 
business, Princess Ruruna will have to make copies of all the relevant files for the Tourism 
Department! 


& 
| 


TOURIOM 
DEPARTMENT 


MERCHANDISE 
DEPARTMENT 


EXPORT 
DEPARTMENT 


New files must 
be created. 


FILE FOR MERCHANDISE DEPT. FILE FOR TOURISM DEPT. 


Strawberry 150G Strawberry 150G 
Apple 1206 Apple 1206 
Lemon 2006 ' Lemon 2006 


This, in turn, increases the amount of duplicated data created when a new department 
starts. Considering these weaknesses, the current system is not efficient. It makes it difficult 
to start new projects and respond to environmental changes. 


A DacaBasE—Znact’S OUR SOLUTIONS 


Well, why is this system so inefficient? The problems all stem from separate and indepen- 
dent data management. What should Ruruna and Cain do? That’s right—they should create 
a database! They must unify the management of data for the entire Kingdom. | will show 
you how to do this in the next chapter. 


(7 | MERCHANDISE BueNESS. 
DEPT. 
DEPT. 


@ Seek 


Data is accessible 
to everyone. 
EXPORT 
DEPT. 


Uniform data management ensures that each department has the correct information, 
because each department sends a query to a single source of data. What an efficient system 
it is! It prevents data conflicts, and it also eliminates duplicated data, allowing for easy intro- 
duction and integration of new departments. 


HOW TO USE A DATABASE 


To introduce and operate a database, you must understand its unique challenges. First, the 
database will be used by many people, so you'll need a way for them to easily input and 
extract data. It needs to be a method that is easy for everybody to use. 


WHAT IS 
THE PRICE OF WHAT WAS THE 
APPLES IN GP SALES VOLUME 


ON MARCH 5? 


(7 | MERCHANDISE pacts 
DEPT. 

DEPT, 

oy) fea 


The new system also presents some risks—for example, it may make it possible for 
users to steal or overwrite important information like salary data, which is confidential 
and should be protected by an access restriction. Or, for example, only the Export Depart- 
ment should have access to sales data. Setting up database security and permissions is 
important when designing a system. 
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I CAN'T 
ACCESS SALES 
DATA. 


MERCHANDISE pberaaeng 
DEPT. 
DEPT. 


ey &oo} 


I CAN 
ACCESS SALES 


The new system can have other problems, too. The database can be used by many 
people at one time. Assume that someone in the Overseas Business Department and some- 
one in the Export Department both try to change the name of a fruit at the same time—the 
former, from Apple to AP, and the latter, from Apple to APL. If they do this, what will happen 
to the product name? For a database that will be used by many people, this kind of problem 
must be considered. 


Crs — 


(7 | MERCHANDISE AN Benes 
DEPT. 
DEPT, 
LS) eu) 


DS 


You also need to be careful not to lose any data. Furthermore, the system may go down 
or a hard disk could fail, causing data to be corrupted. The database must have mechanisms 
to recover from these common kinds of failures. 


We must prepare 
for failures. 


In addition, since the database will hold a large amount of data, you must be able to 
perform searches at high speeds. The new system must have the power to handle that. 

Let's start studying databases together with Princess Ruruna and Cain to learn how to 
solve these problems. Onward to Chapter 2! 


SUMMARY 


* — File-based management can create conflicting data and data duplication. 
* A database allows you to share data easily and prevents conflicting and 
duplicated data. 


USING SOFTWARE TO MANAGE DATABASES 


The database we are going to study is managed by software called a database 
management system (DBMS). A DBMS has many useful functions—it allows you to 

do things like input data into a database, prevent conflicting data, and retrieve a large 
amount of data at high speed. Thanks to our DBMS, the database can be used by many 
people simultaneously. In addition, a DBMS can protect the security of the database— 
for example, it allows the database to operate properly even if a failure occurs. In 
addition, the DBMS provides an easy-to-use interface between the database and its 
users. We'll study databases and the functions of a DBMS in the next chapter. 
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DacaBbase TERMS 
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Wilby 
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BOTH MY FATHER AND 
MOTHER ARE AWAY 
FROM THE CASTLE, 
5O I’M VERY BUSY! 


I THOUGHT YOU'D BE 
LONELY. THAT'S WHY I 
AM HERE. 


YOU CAN’T 
MEAN YOUR recs 
AIDE IS MORE . ° 
DEPENDABLE 
THAN A PRINCE! 


TKAREELS 


YOU PROMISED 
TO GO OUT ON 
A DATE WITH ME 


THIS IS 
FOR YOU. 


HE IS 50 
ANNOYING. 


RURUNA, 
: Ti Be Uf 


BUT RAMINESS |S 


: | THE PRINCE OF 
WAY) THE NEIGHBORING 
‘ COUNTRY. 


YOU SHOULDN'T 
TREAT HIM SO 
LIGHTLY. 


NOOR 


IT’S NOT A GOOD 


GEE! HOW LONG 
HAVE YOU BEEN 
THERE? 


MORNING AT ALL. 
YOU ARE SO CAREFREE. 


YOU SURPRISE 


SINCE YOU 
OPENED THE 
BOOK A LITTLE 
WHILE AGO. 


BUT THAT'S 
OKAY. ANYWAY, 
RAMINESS LEFT. 


LET'S START TO DESIGN 
A DATABASE. 


SQUEEZE 
— SQUEEZE 


YOU CAN'T DESIGN A ene 
DATABASE WITHOUT FOUNDATION 
ANY KNOWLEDGE. IS IMPORTANT. 


LF 


FIRST OF ALL, LET’S 
LEARN DATABASE 
TERMS. 
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N...NO, 
WHAT DID NOTHING... 


SHE WENT INTO i 1 ano 


THE LAPTOP.!. a 
LY «ali, 


THIS IS ONE OF 
THE FILES YOU ~ 
ARE USING. 7 


A PIECE OF DATA IN ONE PRODUCT IS ONE 
THE FILE IS CALLED A RECORD, RIGHT? 


RECORD. 


THEN THE PRODUCT 
CODE, PRODUCT 
NAME, UNIT PRICE, AND 
REMARKS ARE FIELDS, 
CORRECT? 


AND EACH ITEM IN THE 
RECORD |S CALLED A FIELD. 
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EACH RECORD CONTAINS 
FIELDS OF THE SAME TYPE. 


UNIT PRICE REMARKS 


PRODUCT CODE 


PRODUCT NAME 


eee anneal 
en | 2 | _d 
aE 5) re 


L0\ 


wo [ 
pe | 


a 
1o4 LEMON 


FOR EXAMPLE, 
PRODUCT CODE 
IS A THREE-DIGIT 


AND PRODUCT NAME THEN, NEXT, LET'S THINK 
IS TEN CHARACTERS | (01 | ABOUT THE PRODUCT 
OR LESS. 


PRODUCT 
CODE 


0 
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NO TWO AND THERE ARE NO 

PRODUCT fy N DUPLICATED RECORDS. 
CODES ARE / ' 50, IF YOU KNOW THE 
THE SAME. } ‘ ” PRODUCT CODE |S 101, 


YOU CAN IDENTIFY IT 
AS MELON. 


YOU WILL NOT 

COE Breed KNOW WHETHER IT 

NUMBER. INDICATES LEMON 
OR KIWI. 


EVEN IF YOU 
KNOW A FRUIT’S 
PRICE IS 2006... 
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SO WE CAN IDENTIFY 
DATA WITH ITS PRODUCT IS CALLED UN/QUE. 
CODE, BUT NOT WITH 
ITS UNIT PRICE. 


UNIQUE? 


exactly. Wig es OTHER PEOPLE 
came OFTEN SAY THAT 
ABOUT MY FATHER... 
Ko” 
IN THE DATABASE \ wa a BAY SAAR 
WORLD, SUCH A : VI. we unrone 


IT MEANS THE 
ONE AND ONLY. 


THEN, NEXT, LET'S 
THINK ABOUT 
REMARKS. 


IT HAS A 
SPECIFIC MEANING, 
YOU KNOW. 


REMARKS ARE 
REMARKS, AREN'T 


SOME VALUES UNDER 
REMARKS HAVE NO 
ENTRIES, RIGHT? 


TAKE A LOOK FROM 
THE POINT OF VIEW 
OF A DATABASE. 


THIS DOES NOT IF THAT'S SO, YOU 
MEAN THAT A SPACE CAN'T IDENTIFY THE 


REMARKS IS ENTERED... PRODUCT EVEN IF 


IT IS TRULY EMPTY. 


SOUR 


WITH BUR 


Ce s5 
i LSS 


THE ABSENCE OF A VALUE 
PRODUCT f IS CALLED A NULL IN THE 
Nae DATABASE WORLD. 
te | 
21 | CHESTNUT 100G b A NULL IS ACCEPTABLE FOR 
La fevesnen | to0e REMARKS, BUT NOT FOR 
| 202 |rersmmon| 1606 _ | fi. PRODUCT CODE, WHICH 
IDENTIFIES DATA 


: ~N NULL? 
1 - x a\ ‘ EMPTY? 
THAT'S ALL FOR SN eee Q \ UNIQUE? 


DATABASE TERMS. 


DO YOU 
UNDERSTAND? 


WHAT IS A RELATIONAL DATABASE? 331 


BUT, IF YOU CONTINUE 
USING THE CURRENT 
INDEPENDENT FILES, 


) ae 
a 


THAT’S WHY I WANT TO 
CREATE A DATABASE. 


THERE ARE ALL KINDS 
OF PROBLEMS YOU 
CAN'T SOLVE. 


THIS IS A 
HIERARCHICAL DATA 
MOPEL, |IN WHICH 


WHEN YOU SAY 
DATABASE, YOU MUST) 
UNDERSTAND THAT THERE | * 4, 
ARE MANY KINDS OF ab 7 THERE IS A TREE-LIKE 
DATABASES. ) 6011 | RELATIONSHIP BETWEEN 


ay 
Vi 
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NEXT IS THE NETWORK DATA 
MODEL, \N WHICH PIECES 
OF DATA HAVE OVERLAPPING 
RELATIONSHIPS WITH EACH 


Ny, ME RAR 
OTHER, para) ween 


ARE YOUNOT 
I’M READY FOR 
ASTONISHED AT ANYTHING! 


ALL, CAIN? 


THEN, ARE WE GOING 
TO USE ONE OF THEM? 


AS A MATTER OF 
FACT, ANOTHER KIND 
IS MUCH EASIER TO 

USE THAN THESE 


SCARED, 
WEREN’T NO, NOT 
YOU? AT ALL. 


A RELATIONAL DATA MODEL. 
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RELATIONAL Databases 
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: THE RELATIONAL DATA 
DATA DATA DATA DATA MODEL |S BASED ON A 
TWO-DIMENSIONAL TABLE. 
DATA DATA DATA DATA 
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SOMETHING 
APPEARED AGAIN. \ | 


IN THE RELATIONAL 
DATA MODEL, A TABLE 
IS ALSO CALLED A 
RELATION. 


IT SEEMS THAT DATA 
SUCH AS PRODUCTS IS 
EASY TO TABULATE.... 


ONE PIECE OF DATA OR 
RECORD |S CALLED A 
ROW... 


AND EACH DATA ITEM 
OR FIELD IS CALLED A 
COLUMN. 


ANOTHER 
NEW WORD! 
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IN ADDITION, 

A FIELD IS 
SOMETIMES GIVEN 
AN IMPORTANT 
ROLE IN THE 
DATABASE. 


YES. FOR 
EXAMPLE, 


THE PRODUCT 
CODE IN THE FILE 
YOU SAW A LITTLE 
THIS SPECIAL FIELD € WHILE AGO. 


IS CALLED A KEY. 


THE FIELD SERVES AN WELL, I’M FAMILIAR 
IMPORTANT ROLE: TO WITH TABLES. 
IDENTIFY DATA. 
IT IS EASY TO 
UNDERSTAND IF YOU 


CAN PROCESS DATA 
USING A TABLE. 


THIS CODE 
IS CALLED A THIS IS ONE MERIT 
PRIMARY KEY. OF THE RELATIONAL 
DATA MODEL. 


EVEN PEOPLE WHO 
I DIDN’T KNOW DO NOT KNOW MUCH 
THERE WERE SO ; ABOUT DATABASES 
MANY TERMS. CAN PROCESS DATA. 
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AS I SUSPECTED, 
ER...MATH? THIS IS 

IN ADDITION, THE DIFFICULT... 

RELATIONAL DATA 
MODEL IS DESIGNED 

SO THAT YOU CAN 

PROCESS DATA 
WITH MATHEMATICAL 
OPERATIONS. 


Page" | PReReT 
| 102 |errawscmn| 00 | 
103 June | zoe | | 


FOR INSTANCE, LET'S 
LOOK BACK AT THE 
PRODUCT TABLE. 


YOU CAN 


EXTRACT THE 
AN OPERATION 
PRODUCT NAME? TO EXTRACT A 
COLUMN LIKE 
THIS IS CALLED 
PROJECTION. 
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SO EXTRACTING THE 
PRODUCT NAME |S AN 
OPERATION? 


THERE ARE MANY 
OTHER OPERATIONS. 
IN FACT, THERE ARE 

EIGHT! 


CARTESIAN 
PRODUCT 


ANOTHER MERIT OF THE 


RELATIONAL DATA MODEL LJ 


I5 THAT YOU CAN PROCESS | 


DATA BY... i 


COMBINING THESE — (/ 
OPERATIONS. 


I SEE. 
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WON'T WE? 


50 THEN, WE WILL CREATE 
FOR THE KINGDOM OF 
KOD, 


A RELATIONAL DATABASE 


PRINCE RAMINESS 
LEFT A LITTLE WHILE 


HOW MANY 
WOMEN 
DOES HE...2! fP 


*TEE-HEEEEEE 


OH, PARDON ME. 
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ZYUPES OF Data MODELS 


When you use the term database, what kind of database do you mean? There are many 
types available for data management. The data association and operation methods that a 
database uses is called its data model. There are three commonly used data models. 

As | described to Ruruna and Cain, the first type is the hierarchical data model. In the 
hierarchical data model, child data has only one piece of parent data. The second type is the 
network data model. Unlike the hierarchical data model, in the network data model, child 
data can have multiple pieces of parent data. 


Be, SER 


Hierarchical data model Network data model 


To use either of these models, you must manage data by keeping the physical location 
and the order of data in mind. Therefore, it is difficult to perform a flexible and high-speed 
search of your data if you use a hierarchical or network data model. 

The third type of model is the relational data model. A relational database processes 
data using the easy-to-understand concept of a table. Let’s discuss this model in more 
detail. 


Relational data model 


Datwa EXTRACTION OPERATIONS 


How is data extracted in a relational database? You can process and extract data in a rela- 
tional database by performing stringently defined mathematical operations. There are eight 
main operations that you can use, and they fall into two categories—set operations and rela- 
tional operations. 


SET OPERATIONS 


The union, difference, intersection, and Cartesian product operations are called set 
operations. These operations work upon one or more sets of rows to produce a new set of 
rows. In short, they determine which rows from the input appear in the output. Let’s look at 
some examples using Product Table 1 and Product Table 2. 


WHAT IS A RELATIONAL DATABASE? 39 


40 CHAPTER 2 


PRODUCT TABLE 1 


UNION 


PRODUCT TABLE 2 


Carrying out the union operation allows you to extract all products included in Product 


Table 1 and Product Table 2. The result is below. 


Performing a union operation extracts all rows in the two tables and combines them. 


The following figure shows what the data from the two tables looks like once a union 


operation has been performed. All rows in Product Table 1 and Product Table 2 have been 


extracted. 
‘a > 
PRODUCT PRODUCT 
TABLE 1 TABLE 2 


DIFFERENCE 


Difference is an operation that extracts rows from just one of the tables. For example, a dif- 
ference operation can extract all of the products from the first table that are not included in 
the second. The results depend on which table contains rows to extract, and which table has 
rows to exclude. 


Apple 1206 


i >) (— >) 
PRODUCT PRODUCT PRODUCT PRODUCT 
TABLE 1 TABLE 2 TABLE 1 TABLE 2 


INTERSECTION 


You can also extract products that are included in both Product Table 1 and Product Table 2. 
This operation is called an intersection operation. Here is the result of the intersection of 
Product Tables 1 and 2. 


—_——SS————— OO "— 


PRODUCT PRODUCT 
TABLE 1 TABLE 2 
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CARTESIAN PRODUCT 


The Cartesian product operation is a method that combines all rows in the two tables. Let's 
look at the Product and Export Destination Tables below. 

The Cartesian product operation combines all rows in the two tables. In this example, it 
resulted in 3 x 3 = 9 rows. Notice that the column names (or fields) in these two tables are 
not the same—unlike our previous examples. 


PRODUCT TABLE EXPORT DESTINATION TABLE 


2 
2 


2 
P P rows 
The Kingdom of Ritol 


CARTESIAN PRODUCT 


Fics vein 2006 [42 | The Kingdom of nan 
fica [wen [2006 [23 [sha Empre | 
faoa [wen [2006 [25 | Te kingdom of Rot | 
face stawberny [2506 [42 |The kingdom of Winer 
face [strawberry [2506 [23 [ashame | 3°37 
face [strawberry [2506 [25 | Te Kingdom of Rot | 
fica [arse [3206 [42 | The kingdom of Minar 
fica [Aarne [1206 [23 [sha empire | 


101 
101 
101 
102 
102 
102 
103 
103 

03 
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RELATIONAL OPERATIONS 


A relational database is designed so that data can be extracted by set operations and rela- 
tional operations. Let’s look at the other four operations specific to a relational database, 
called relational operations—projection, selection, join, and division. 


PROJECTION 


Projection is an operation that extracts columns from a table. In the example shown here, 
this operation is used to extract only product names included in the Product Table. 


Strawberry 


Apple 


Think of projection as extracting “vertically,” as shown below. 


LI | 


SELECTION 


The selection operation extracts two rows from a table. 


Selection is like projection, but it extracts rows instead of columns. Selection extracts 
data “horizontally.” 


= 
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JOIN 


The join operation is a very powerful one. This operation literally refers to the work of join- 
ing tables. Let’s look at the tables below as an example. 


PRODUCT TABLE SALES TABLE 


The Product Code columns in these two tables represent the same information. On 
November (st, 1,100 strawberries (product code 102) were sold. The Sales Table does not 
include the product name, but it does include the product code. In other words, the Sales 
Table allows you to understand which product was sold by making reference to the product 
code, which is the primary key in the Product Table. The product code in the Sales Table is a 
foreign key. Joining the two tables so that the foreign key refers to the primary key results in 
the following table. 


This creates a new dynamic table of sales data, including date, product code, product 
name, unit price, and quantity. The figure below shows a join—the shaded area represents a 
column that appears in both original tables. 


HU 
TL 


DIVISION 


Finally, let’s look at division. Division is an operation that extracts the rows whose column 
values match those in the second table, but only returns columns that don't exist in the sec- 
ond table. Let’s look at an example. 


SALES TABLE EXPORT DESTINATION TABLE 


The Kingdom of Minanmi The Kingdom of Minanmi 
The Kingdom of Minanmi | 3/10 Alpha Empire 


The Kingdom of Ritol 3/21 
The Kingdom of Sazanna | 3/25 


Dividing the Sales Table by the Export Destination Table results in the following table. 
This allows you to find the dates when fruit was exported to both the Alpha Empire and the 
Kingdom of Minanmi. 


[bate 


QUESTIONS 


Now, let’s answer some questions to see how well you understand relational databases. The 
answers are on page 48. 
Qi 


What do you call the key referring to a column in a different table in a relational 
database? 


Q2 
The following table displays information about books. Which item can you use as a 
primary key? The ISBN is the International Standard Book Number, a unique identifying 
number given to every published book. Some books may have the same title. 
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Q3 
What do you call the operation used here to extract data? 


The Kingdom of Minanmi 


The Kingdom of Ritol 


The Kingdom of Ritol 
The Kingdom of Sazanna 


Q4 
What do you call the operation used here to extract data? 


Export dest. code | Export dest. name 
12 
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Qs 
What do you call the operation used here to extract data? 


[emare dest code [outa] 


[Export dest code [Date [Export dest name] 


ZHE RELATIONAL DataBase PREVAILS/ 


In a relational database, you can use eight different operations to extract data. The extracted 
results are tabulated. If you combine the operations explained in this section, you can 
extract data for any purpose. For example, you can use the name and price of a product to 
create gross sales aggregate data for it. Relational databases are popular because they're 
easy to understand and provide flexible data processing. 
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SUMMARY 


ANSWERS 
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Qi 
Q2 
Q3 
Q4 
Qs 


One row of data is called a record, and each column is called a field. 

A column that can be used to identify data is called a primary key. 

In a relational database, you can process data using the concept of a table. 

In a relational database, you can process data based on mathematical operations. 


Foreign key 
ISBN 
Selection 
Union 


Join 
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LET'S DESIGN A VAaTABAsSE/ 


WHAT'S WRONG 
WITH CAIN? 


CAIN? WHERE 
oe 
ARE YOU? HE IS MUMBLING 
TO HIMSELF... 


DATABASE OR 
SOMETHING... 


MORNING, 
GIRLS! 


PRINCESS 
RURUNA! 


TAKES A Li LV \ GOOD 
LONG LOOK... Gq @ : MORNING, 
| \ a TICO. 


CAIN, YOU NEED TO 


BE CAREFUL! 
PRINCESS 


RURUNA. 


GOOD MORNING, 
RURUNA!! 


NOBODY CAN SEE YOU LOOK WEIRD SORRY...YOU 
TICO BUT YOU IF YOU TALK TO ARE RIGHT. 
HER IN FRONT OF 
OTHER PEOPLE. 


50 WHAT WERE 
YOU TALKING 
ABOUT? 


I HARDLY KNOW WHERE YOU MUST HAVE 
TO BEGIN WHEN CREATING BEEN WORKING 
A DATABASE. ‘ can ALL MORNING. 
50 I WAS ASKING 
TICO’S ADVICE. 
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ane pale 
FIRST OF ALL, WE TICO SAYS IT’S LO 
CONSIDERED THAT WE APPROPRIATE TO CREATE iad 
COULD EASILY CREATE A MODEL AND ANALYZE 
A DATABASE... THE CURRENT EXPORT 
MANAGEMENT 
BASED ON IT. 


IF WE COULD JUST ; 

FIGURE OUT THE ACTUAL : 

CONDITION OF THE WE HAVE TO STUDY 
KINGDOM OF KOD.... SOMETHING NEW. 


WELL, THAT'S ALL. 


WELL, ARE YOU 
READY? 
WE'LL USE A 
: MODEL FOR 


C = ANALYSIS CALLED... 


AN E-R MODEL! 


E REFERS TO EN7/TY AND 
R TO RELATIONSHIP. 


I DON’T KNOW 
THESE TERMG.... 
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IN THE E-R MODEL, YOU 
CONSIDER THE ACTUAL ILL CLARIFY 
WORLD USING THE THAT A BIT... 
CONCEPTS OF ENTITY 
AND RELATIONSHIP. 


ENTITY REFERS TO FOR EXAMPLE, WHEN 
A RECOGNIZABLE = EXPORTING FRUIT TO OTHER 
OBJECT IN THE COUNTRIES, FRUIT AND 
ACTUAL WORLD. EXPORT DESTINATION CAN BE 
CONSIDERED ENTITIES. 


AND ASSOCIATING 
AN ENTITY WITH 
ITS PROPERTIES 


RESULTS IN... UNIT PRICE 


EXPORT, DEST. ¢ 


EXPORT 
DESTINATION 
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YOU HAVE ANALYZED THEN, WHAT IS A 
FRUIT AND EXPORT ; RELATIONSHIP? 


DESTINATIONS. 


IT REFERS TO HOW 
ENTITIES RELATE TO 
EACH OTHER. 


FRUIT AND EXPORT 50 WE CAN 
DESTINATION ARE CONSIDER 
ASSOCIATED WITH EACH SALES TO 
OTHER BECAUSE YOU BE THE 
SELL FRUIT TO EXPORT RELATIONSHIP. 
DESTINATIONS. 


SQUEEEEAKY 
OO : 


Re . ZHE KINGDOM OF KOD EMPIRE 


FRUIT IS EXPORTED 
TO MANY COUNTRIES, 
AND EACH EXPORT 
DESTINATION 
PURCHASES MANY 
KINDS OF FRUIT. 


OF RITOL 


ZAE KINGDOM 
OF minanm| 


FRUIT FROM EXPORT 
THE KINGDOM SEER DESTINATION 


MANY EXPORT 
DESTINATIONS (WV) ARE 
ASSOCIATED WITH MANY 
FRUIT CM). 


IF YOU THINK 
ABOUT THIS... 
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EXPORT 
DESTINATION 


ONLY APPLES 


CAIN-BRAND 


WELL THEN, IF CAIN \|__“PFLE? @ 


SELLS JUST ONE 
KIND OF FRUIT TO 
VARIOUS FAMILIES, 


AND THEREFORE, 
THIS IS THE ACTUAL 
CONDITION OF THE ~ 
KINGDOM OF KOD. i 


THE E-R MODEL 
SHOWS US THE 
ACTUAL CONDITION, 
DOESN'T IT? 


THE RELATIONSHIP IS 
CALLED MANY-TO-MANY. 


IN THE E-R MODEL, THE 
NUMBER OF ASSOCIATIONS 
BETWEEN ENTITIES IS 
CONSIDERED. 


THEN THE 
RELATIONSHIP IS 
ONE-TO-MANY? 


THIS IS HOW THE 
KINGDOM OF KOD’S 
EXPORT BUSINESS 


WORKS! 


MOBRMALIZING A ZABLE 


NOW THAT YOU KNOW 
ABOUT THE ACTUAL 
CONDITION OF THE 


THAT'S RIGHT! THE 
FIRST THING TO DO 
IS TO ANALYZE THE 


IT IS DIFFICULT TO ACTUAL CONDITION. KINGDOM OF KOD... 
START TO CREATE A THAT IS VERY 


DATABASE. — IMPORTANT. 


MUTT 
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LET'S CONSIDER THE 
DESIGN OF AN ACTUAL 
DATABASE. 


\f 

\ 

\N 
SS 


e) 
W- x1 
Berry @15 OGx pte 880, 0006 
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THIS REPORT 


THIS I9...A SALES 


SHOWS THE 
REPORT WE CREATE / l CURRENT STATUS 
WHEN EXPORTING [7% OF EXPORT MOST 
FRUIT TO A FOREIGN CORRECTLY. 


YES, INDEED! 50, WE 
TAKE ALL THE DATA 
FROM THE REPORT... 


TO CREATE A 
DATABASE TABLE. 


EXPORT PRODUCT | PRODUCT 
1101 THE KINGDOM 

OF MINANMI 

THE KINGDOM 

THE KINGDOM 


THE KINGDOM pene aia oc 
NOS BZ 25 OF RITOL 
104 LEMON ZO00G 700 


ZABLE CREATED FROM Sales KEPORT 
57 


THAT'S GREAT!! \ 
THIS CAN BE OUR e FOR A RELATIONAL 


DATABASE. DATABASE, YOU HAVE 
; TO MAKE THE TABLE 
AS EASY TO USE AS 

POSSIBLE. 


SORRY, BUT YOU CAN’T 
USE IT AS IT IS. NOT YET... 


YOU SEE, THERE 
DO YOU MEAN ARE TWO ROWS 
THIS TABLE |S OF PRODUCT ITEMS 
NOT EASY TO IN ONE ROW OF ie 


UNDERSTAND? 


IT WOULD BE EASIER 
FOR YOU TO UNDERSTAND 
IF EACH ROW OF THE 
TABLE HAD JUST ONE 
VALUE. 


THAT'S BECAUSE 
WE SOMETIMES 
PROCESS TWO OR 
MORE PRODUCTS ; 
USING ONE SALES /{/[ THAT'S 
REPORT. | RIGHT. 


NOT BY CREATING ONE 
TABLE USING THE DATA 
AS IT IS, 


BUT BY DIVIDING IT INTO 
MULTIPLE TABLES! 


BUT THIS IS MUCH 

MORE DIFFICULT 

THAN THE SINGLE 
TABLE... 


BUT IT IS IMPORTANT WHAT?! I 
TO MANAGE DATA WAS JUST 


IT MAY LOOK 


COMPLICATED, THINKING... 


CORRECTLY AND 
COMPATIBLY. 


FIGURE OUT 
THE ACTUAL 
CONDITION... MACK 


LET’S DESIGN A DATABASE! 54 


ASSUME WE WANT IF YOU USE THIS 
TO RAISE THE UNIT TABLE AS IT IS, 
PRICE OF MELON ‘ 


YOU HAVE TO 
FIND ALL ROWS 
FOR MELON AND 
CORRECT THE UNIT 
PRICE. 


BUT, IF YOU HAVE 


ONLY HERE!! 
\ PRODUCT 
TABLE 
A TABLE RELATING § 
ONLY TO PRODUCTS, : 


1506 


=| APPLE 120G 

YOU CAN CORRECT \ L00G 

THE PRICE IN JUST ONE ees 
PLACE—ONE ROW IN 

THE PRODUCT TABLE. 


NO CONFLICT WILL OCCUR, 
EVEN IF YOU FORGET TO 
CORRECT ANY OTHER 
ROWS!! ISN’/T THAT GREAT? 


YOU KNOW, USING 

: I SEE. VIEWED IN 
A SINGLE TABLE 
MAKES IT EASY THIS LIGHT, IT IS 
TO FORGET TO 


IS CALLED 
INCONVENIENT. 
CORRECT DATA. 


50, WHAT AM I 
NORMALIZATION. SUPPOSED TO 


NORMALIZATION, YES, THIS Is 
NORMALIZATION |Iyj56 IMPORTANT! 
MUMBLING, |} A 


DIVIDING THE TABLE 
TO PREVENT DATA 
CONFLICTS LIKE THIS 
FROM OCCURRING... 
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LET'S TRY 
CHANGING IT 50 REPEATED DATA IS A CLUE 
THAT ONE ROW THAT ROWS HAVE TO BE 
HAS ONE VALUE. DIVIDED. 


ONE TABLE WITH DATE, 
EXPORT DESTINATION 
CODE, AND EXPORT 
DESTINATION NAME... 


50, I'LL DIVIDE IT INTO... 


AND ANOTHER TABLE WITH 
PRODUCT CODE, PRODUCT 
NAME, UNIT PRICE, AND 
QUANTITY. 


| SALES TABLE (FIRST NORMAL FORM (1D) 


| mor |e || en | 
| toa | so || ee nan 


BUT THE REPORT 
CODE |S PROVIDED 
IN BOTH TABLES, 
ISN’T IT? 


SALES TABLE (FIRST NORMAL FORM (2)) 


PRODUCT | PRODUCT | UNIT 
REPORT cope| PRODUC QUANTITY 
eee ee 


300 


YES, THAT WAY 
YOU CAN IDENTIFY 


IF THERE IS AN 
ASSOCIATION 
| os | tos |wne | zoe BETWEEN THE 


TWO TABLES. 
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THE TABLE THAT RESULTS 
FROM A DIVISION LIKE 
THIS IS CALLED THE 
FIRST NORMAL FORM. 


LET'S SEE... 


WAIT A 
MINUTE. 


THE TABLE THAT 
HAS ROWS WITH 
TWO OR MORE 
VALUES BEFORE IT 
IS DIVIDED IS CALLED 
THE UNNOKMALIZED 
FORM. 


IT MEANS THAT 
THE FIRST NORMAL 
FORM IS CREATED 

BY DIVIDING THE 

UNNORMALIZED FORM. 


THESE ARE THE “FIRST 
NORMAL FORMS.” DOES 
THAT MEAN THERE ARE THE 
"GECOND” AND “THIRD” 
NORMAL FORMS, TOO? 


HANG IN 
THERE! 


THE FIRST NORMAL FORM 


CANNOT BE USED AS A 
RELATIONAL DATABASE 
TABLE AG IT I9. 


MC. RELation Le 
DataBase 
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FIRST NORMAL 
FORM 


BINGO! 


REPORT PRODUCT | PRODUC UNIT 
veusrentooe | 
NORMAL FORM (2) 1@ » | 101 [meLon | 8006 | 1100 | 

} 
a ee eee 


whe SALES STATEMENT TABLE 
HERE YOU (~ (FIRST NORMAL FORM (1) 
ja : 


Ani YOU CAN'T MANAGE 
IT’S THE SALES "4 PRODUCTS WITH THIS AIEE!! WHY? 


STATEMENT TABLE. TABLE YET. 


WHAT DO YOU 


IF YOU RECEIVE 
MANDARIN ORANGES, 


YOU CAN’T ADD 
THEM TO THIS 
TABLE IF THEY 
HAVE NOT BEEN 
SOLD YET. 


BECAUSE NO SALES 
HAVE BEEN REPORTED, 
THE REPORT CODE AND IN TABLE (2), DATA 
QUANTITY ARE UNKNOWN. RELATING TO 
PRODUCTS AND 


SALES IS MIXED. 


ie WITHOUT SALES 
y ze 


We 


LACK m Ry i, 
CODE 
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YOU CAN’T MANAGE 
PRODUCTS 
INDEPENDENTLY USING 
TABLE (2). 


THESE ARE THE TABLES THAT 
RESULT FROM DIVIDING THE FIRST 
NORMAL FORM (2) INTO TWO. 


PROVUCT | PRODUCT 
ZoHN UNIT PRICE 


TABLE (1) CONTAINS 
DATA RELATING TO THE 
PRODUCTS. 


IF A VALUE IN THE PRODUCT 
CODE COLUMN IS DETERMINED, 
WE CAN FIND THE VALUES IN THE 
PRODUCT NAME AND UNIT PRICE 
COLUMNS. 


SO THAT MEANS THE 
PRODUCT CODE, AS 
THE PRIMARY KEY, 
DETERMINES VALUES IN 
OTHER COLUMNS. 


EXACTLY. 
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FOR DATA J FOR TABLE (2), CONSIDER THE 
RELATING TO COMBINATION OF REPORT 


SALES STATEMENT CODE AND PRODUCT CODE AS 
ITEMS IN TABLE (2), Lies. A PRIMARY KEY. 


AND IN THIS TABLE, | 
THE PRIMARY 
KEY DETERMINES 
VALUES IN OTHER 
COLUMNS. 


IN SOME CASES, TWO" IN OTHER CASES, ONE KIND 
KINDS OF PRODUCTS OF PRODUCT SELLS IN 
SELL AT THE SAME , DIFFERENT QUANTITIES. 


THIS MEANG... 


YOU DIVIDE THE TABLE SO 
THAT WHEN A PRIMARY KEY IS 


DETERMINED, VALUES IN OTHER 
COLUMNS ARE DETERMINED. REPORT CODE 


UNDERSTAND? 
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THE TABLE THAT E CAN E e 
RESULTS FROM oi pend WE of EVEN IF THE PRICE OF 
DIVISION ACCORDING WERE TALKING ABOUT MELON CHANGES, WE 
TO THIS RULE IS EARLIER TO THE SECOND JUST CORRECT THE 
CALLED NORMAL FORM (1). ~\ DATA ONENE ROW, 


WHICH HAVE NOT 
WE CAN ALSO ADD JIS», BEEN SOLD YET! 
KIWIS AND GRAPES, 


." 


«) ee 
Qay 


THE SECOND 
NOKMAL FORM. 


..BY THE WAY, YOU 
DIVIDED THE FIRST 
NORMAL FORM (2), 


ee ee 
ae ee 
68 [aro | 


THE KINGDOM 
| THE RNGEOM | RITOL 
50 ISN'T IT NECESSARY TO 


DIVIDE THE FIRST NORMAL Veter | ie 
FORM SALES TABLE (I)? / , 


uw 
nn 
= 
o 
ul 


FOR THIS TABLE, IF A 
ONE VALUE IN REPORT CODE IS 
DETERMINED, ALL OTHER VALUES IN 
DATE, EXPORT DESTINATION CODE, 
AND EXPORT DESTINATION NAME ARE 
DETERMINED. 


GOOD POINT! 
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WHAT DO YOU CALL A TABLE 
IN WHICH VALUES IN OTHER 
COLUMNS ARE DETERMINED 
WHEN THE PRIMARY KEY IS 
DETERMINED? TYR 50, THIS TABLE IS A 
SECOND NORMAL FORM, 
RIGHT? 


= ee 
ee SALES TABLE <— 
(SECOND NORMAL FORM (3)) 


-—freront cove] DATE | pet 26ve | vest name 

THE KINGDOM THE KINGDOM 

THAT'S RIGHT. YOU ae tHE secon wena 
ALPHA EMPIRE ALPHA EMPIRE 

CONSIDER THE FIRST = \_|APHAeMPiRe] Oe ee ca) «(ena cries 


NORMAL FORM (1)... eS) 


HANG IN 
WE HAVE COMPLETED THERE! 
THE FIRST AND 
SECOND NORMAL AS 
FORMS! Mee 


NOW, OUR 
RELATIONAL 
DATABASE |S 

COMPLETEDI? 


HOLD ON A 
SECOND... 
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LOOK AT THE SECOND NORMAL 
FORM (3) AGAIN. 


| ZALES TABLE 


THE KINGDOM OF SAZANNA, 
TO WHICH NO FRUIT HAS 
BEEN EXPORTED, CANNOT BE 
MANAGED BY ADDING IT TO 
THIS TABLE. 


YOU CAN’T MANAGE 
EXPORT DESTINATIONS 
WITH THIS TABLE. 


3/5 
3/7 
3/8 


4 THE KINGDOM 
OF MINANMI 


THE KINGDOM 
OF RITOL 


IN TABLE (3), DATA 
RELATING TO EXPORT 
DESTINATIONS AND 


SALES IS MIXED. 


THE KINGDOM 
OF SAZANNA 


HOW CAN WE 


MANAGE EXPORT Se 
DESTINATIONS ae 
INDEPENDENTLY? i 


EXPORT EXPORT 
DEST. CODE DEST. NAME 
1Z THE KINGDOM 
OF MINANMI 
THE KINGDOM 


BUT IN FACT, 

IN THE SECOND NORMAL DETERMINATION REPORT 

FORM (3), EXPORT OF REPORT CODE 
DESTINATION NAME IS DETERMINES A 


DETERMINED ACCORDING A VALUE IN EXPORT = 


TO REPORT CODE. ine. DESTINATION CODE, 
DESTINATION 


C 
THEREBY 
DETERMINING EXPORT “— 


ODE 
DESTINATION NAME 
INDIRECTLY. 


TO DEAL WITH i @ oI 
SUCH CONCERNS, We |) INS 8/ YOU DIVIDE THE TABLE SO 
& | THAT NO PART IS DETERMINED 
INDIRECTLY. 


EXPORT EXPORT EXPORT 
RERORICOTE || JPAlE DEST. CODE DEST. CODE DEST. NAME 


NOW, YOU CAN 7 
FINALLY, WE/VE MANAGE EVEN 7 
GOTTEN TO THE Z OE ENS ame 
THIRD NORMAL a 


THAT'S RIGHT. A TABLE THAT 
DOES NOT ALLOW ANY NON- 
PRIMARY KEY TO DETERMINE 
VALUES IN OTHER COLUMNG... 


RN AINX 

EN © ©\ 

" SA se. 
<> 


IS CALLED THE 
THIRD NORMAL FORM!! 
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EXPORT DESTINATION 
SALES TABLE | TABLE 


[0 [nee 


SALES STATEMENT 
TABLE 


PRODUCT TABLE 


PRODUCT PRODUCT 


THESE ARE THE 
TABLES THAT RESULT 
WHEN YOU DIVIDE 
A TABLE UP TO THE 
THIRD NORMAL FORM. 


Vy A RELATIONAL DATABASE 

NORMALLY USES TABLES 

DIVIDED UP TO THE THIRD 
NORMAL FORM. 


DRUINSVLED 


NOW, OUR 
DATABASE TABLE 
IS COMPLETE! 


CAINE: * PRINCESS? 


_ ¢g 


ial / 


4 


aa 


\ i] 


NOW, YOU CAN MANAGE 
PRODUCTS, EXPORT 
DESTINATIONS, AND SALES 
ON A TABLE-BY-TABLE 
BASIS, 


50 YOU CAN MANAGE 
THEM WITHOUT ANY 
PROBLEM. 


THOUGH WE DIVIDED THE 
ORIGINAL TABLE INTO MANY 
ADDITIONAL TABLES, 


THIS TABLE SHOWS 
RELATIONSHIPS 
BETWEEN DATA. 


NO CONFLICT WILL 
OCCUR EVEN IF YOU 
ADD DATA. 


RELIEVED... 


THE ORIGINAL DATA IS 
INCLUDED IN ALL OF THE 
TABLES. 


EXPORT 
DESTINATION TABLE 


EXACTLY! IT IS 
RELATIONAL. 
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EXPORT —— ~ EXPORT 
[_kerort cove |] pare 
= eel 


THE EXPORT DESTINATION 
CODE IN THE SALES TABLE 
REFERS TO THE EXPORT 
DESTINATION CODE IN THE 
EXPORT DESTINATION TABLE. IN THE SAME MANNER, THE 
PRODUCT CODE IN THE SALES 
STATEMENT TABLE REFERS TO 
THE PRODUCT CODE IN THE 
PRODUCT TABLE, 


PRODUCT 
REPORT CODE 


PRODUCT : 
CODE : 


AND THE REPORT CODE IN THE 
SALES STATEMENT TABLE REFERS 
TO THE REPORT CODE IN THE 
SALES TABLE. 


THE REFERRING Bl ee pronal SEPARATE AND 
COLUMN IS CALLED A 245" Dacasace INDEPENDENT TABLES, 
FOREIGN KEY. BUT THEY ARE DEEPLY 
LINKED BY FOREIGN 
KEYS. 


THE FOREIGN KEY WE'RE... 
REFERS TO THE E 7 ALMOST... 
PRIMARY KEY IN [ \ V7 
OTHER TABLES. 
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I CAN HARDLY WAIT 
TO MAKE EXPORT 
MANAGEMENT RUN MORE 
SMOOTHLY USING OUR 
DATABASE. 


PRINCESS... 
MR. CAIN... 


OH, IT’S 


{ 
ae 
= \ } we 

= J ; RO AUSSI 


YOU TWO HAVE BEEN 
ACTING WEIRD. 


OH, LISTEN... 
I CAN EXPLAIN. 


WHAT'S THE 
MATTER WITH 


A 


YOU DIDN‘T 
TELL THE 
PRINCESS 

SOMETHING 
STRANGE, 
DID YOU, 
MR. CAIN? 


Whac /5 ThE E-B MODEL? 


Princess Ruruna and Cain have figured out the actual condition of the Kingdom of Kod using 
an E-R (entity-relationship) model. When you try to create a database yourself, the first step 
is to determine the conditions of the data you are trying to model. 

Using the E-R model, try to define an entity in your data. An entity is a real-world 
object or “thing,” such as fruit or export destination. 

In addition, an E-R model shows the relationship between entities. Princess Ruruna 
and Cain performed their analysis on the assumption that there was a relationship called 
sales between fruit and export destination. Fruit is exported to multiple export destina- 
tions, while each export destination also imports multiple kinds of fruit. For this reason, an 
analysis was made for the E-R model assuming that there was a relationship called many- 
to-many between fruit and export destinations. M fruit have a relationship with N export 
destinations. The number of associations between entities is called cardinality. 


PRODUCT CODE 
PRODUCT NAME 


UNIT PRICE 


QUANTITY 


EXPORT DESTINATION CODE 


EXPORT 
DESTINATION 


HOW TO ANALYZE THE E-B MODEL 


EXPORT DESTINATION NAME 


How would you perform analyses in the cases below? Think about it. 


CASE 1: ONE-TO-ONE RELATIONSHIP 


One export destination manages one piece of export history information. This kind of rela- 
tionship is called a one-to-one relationship. 


EXPORT DESTINATION 


EXPORT 
DESTINATION 
INFORMATION 


EXPORT HISTORY 
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CASE 2: ONE-TO-MANY RELATIONSHIP 
Multiple servants serve one princess. The servants do not serve any other princess or even 


the king. 


PRINCESS 
RURUNA 


This kind of relationship is called a one-to-many relationship. 


CASE 3: MANY-TO-MANY RELATIONSHIP 


Fruit is exported to multiple export destinations. The export destinations import multiple 
kinds of fruit. 


THE KINGDOM 
OF MINANMI 


This kind of relationship is called a many-to-many relationship. 
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QUESTIONS 


How well do you understand the E-R model? Analyze and draw an E-R model for each of 
the cases below. The answers are on page 82. 


Qi 
One staff member manages multiple customers. One customer will never be contacted 
by more than one staff member. 


(— ae 


THE KINGDOM 
OF MINANMI 


Q2 
One person can check out multiple books. Books can be checked out to multiple 
students at different times. 
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Q3 
Each student attends multiple lectures. Each lecture is attended by multiple students. 
One teacher gives multiple lectures. Each lecture is given by one teacher. 


PRINCESS 
RURUNA 
. INE 


Oo 


Q4 
Each customer can open multiple deposit accounts. Each deposit account is opened by 
one customer. Each bank manages multiple deposit accounts. Each deposit account is 
managed by one bank. 


Keep in mind that E-R model-based analysis does not necessarily produce one “correct” 
result. There can be many ways to logically organize data to reflect real-world conditions. 


LET'S DESIGN A DATABASE! 77 


NOBRMALIZING A ZABLE 
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Princess Ruruna and Cain learned about normalization, the process of tabulating data from 
the real world for a relational database. It is necessary to normalize data in order to prop- 
erly manage a relational database. Normalization is summarized here (the shaded fields are 
primary keys). 


UNNORMALIZED FORM 


Report | Date | Export Export Product | Product | Unit | Quantity 
code destination | destination | code name price 
code name 


FIRST NORMAL FORM 


Report code Export destination code Export destination name 


SECOND NORMAL FORM 


Report code Export destination code 


Product code Unit price 


THIRD NORMAL FORM 


Export destination name 


Report code Export destination code 


Export destination code Export destination name 
Report code Product code | Quantity 


The unnormalized form is a table in which items that appear more than once have not 
been removed. We've seen that you cannot manage data well using this kind of table for a 
relational database. Consequently, you need to divide the table. 

The first normal form refers to a simple, two-dimensional table resulting from division 
of the original, unnormalized table. You can consider it to be a table with one item in each 
cell. The table is divided so that no items will appear more than once. 

The second normal form refers to a table in which a key that can identify data deter- 
mines values in other columns. Here, it is the primary key that determines values in other 
columns. 

In a relational database, a value is called functionally dependent if that value deter- 
mines values in other columns. In the second normal form, the table is divided so that 
values in other columns are functionally dependent on the primary key. 

In the third normal form, a table is divided so that a value is not determined by any 
non-primary key. In a relational database, a value is called transitively dependent if that 
value determines values in other columns indirectly, which is part of functionally dependent 
operation. In the third normal form, the table is divided so that transitively dependent values 
are removed. 


QUESTIONS 


It is important to be able to design a relational database table for various situations, so let’s 
look at some examples of normalizing tables. Determine how the table was normalized in 
each of the cases below. The answers are on page 82. 


a5 
The following table manages book lending like the example in Q2. To what stage is it 
normalized? 


Lending Date Student | Student | Student | Department | Entrance 
code code name address year 
ISBN Publication date | Total page count 
Lending code ISBN 
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Q6 
The following table also shows a book lending situation. To what stage is it normalized? 


Lending code Student code 
Lending code 


Q7 
The following table shows monthly sales for each staff member. Each department has 
multiple staff members. A staff member can only be part of one department. Normalize 
this table to the third normal form. 


Staff Staff Month Member's Department Department 


member member sales code name 


code name 
OVERSEAS 
MERCHANDISE BUSINESS EXPORT 
DEPARTMENT DEPARTMENT, DEPARTMENT 
wy) Seo} 


Q8 


The following table represents an order-receiving system. Normalize it to the third 
normal form. However, process one customer per order-taking code. You can process 
multiple products based on one order-taking code. In addition, one order-taking code 
should correspond to only one representative. 


Date | Customer | Customer | Product | Product } Unit | Represen- | Represen- | Quantity 
code name code name price | tative code | tative name 
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ag 
The following table represents an order-receiving system. Normalize it to the third 
normal form. Assume that products are classified by product code. 


Date | Customer | Customer | Product | Product | Unit | Product Product Quantity 
code name code name price | classification | classification 
code name 


STEPS FOR DESIGNING A DATABASE 


You have learned how to design a database! However, you have to do more than just 

that. You need to design a detailed file structure inside the database and devise methods 
for importing and exporting data. In general, you can divide the whole database design into 
three parts: conceptual schema, internal schema, and external schema. 

The conceptual schema refers to a method that models the actual world. Namely, it is 
a way to determine the logical structure of a database. The conceptual schema is designed 
taking into consideration an E-R model-based understanding of the actual world and nor- 
malization of a table. 

The internal schema refers to a database viewed from the inside of a computer. 
Namely, it is a way to determine the physical structure of a database. The internal schema is 
designed after creating a method to search the database at high speed. 

The external schema refers to a database as viewed by users or applications. The 
external schema is designed after creating data required for application programs. 


CT 


INTERNAL SCHEMA CONCEPTUAL SCHEMA | | EXTERNAL SCHEMA 


Princess Ruruna and Cain have designed a database with a focus on the conceptual 
schema in this chapter. They are in the midst of improving the database. 

Now that you've completed the basic design of a database, we'll go straight to using the 
database in the next chapter. 


SUMMARY 


* — An E-R model is used to analyze entities and relationships. 

* — Relationships between entities can be one-to-one, one-to-many, and many-to-many. 

* — The data in a table must be normalized before you can use it to create a relational 
database. 

* — The design of a database can be divided into three types: conceptual schema, internal 
schema, and external schema. 


LET'S DESIGN A DATABASE! 81 


ANSWERS 


a4 STAFF 03 Q4 
MEMBER STUDENTS CUSTOMER 
1 M ; 


N N 


Q5 Second normal form 
Q6 Third normal form 


Q7 


Staff member code Staff member name Department code 
Department code Department name 
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i=} 


8 


Order-taking code Representative code 


Customer code 


Customer name 


Order-taking code Quantity 


Product code 


Representative code 


Representative name 


i=) 


9 


Order-taking code Customer code 


Customer code 


Customer name 


Product code 


Product classification code 


Product classification code Product classification name 
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DESIGNING A DATABASE 


In this chapter, you learned how to design a relational database. However, there are 
other database design methods. Usability and efficiency of a database depend on an 
analysis and design method. Therefore, it is important to create an appropriate data- 
base in the design stage. 

In the database design stage, you need to perform various tasks in addition to 


table design. For example, you need to consider a datatype to use in the table. You 
may also need to specify columns indicating numerical values, currencies, and charac- 
ter strings. In addition, you need to devise a search method so you can carry out fast 
searches. Sometimes, you must create a design while keeping physical file organization 
in mind. And you have to control which users can access the database to ensure secu- 
rity. There are many factors you need to think about when designing a database. We'll 
look at some of these factors in the following chapters. 
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= 
& 
Vy 
lb 
— 
0 
0 
VY 
c 
Ya 
S 
WO 
= 
Ny 
b> 
0 
‘= 


ANY 


VE Zs 
oY AN 
ARAN 
a Z| 
2 
f L\ 
a 


WN 


YOU OFTEN SKIPPED 
CLASS AND SNUCK OUT 
OF THE CASTLE. 


WALKING 
THROUGH TOWN 
MAKES ME 
REMEMBER MY 
CHILDHOOD. 


PRINCESS!! 
PRINCESS 
RURUNA!! 


YOU CAN'T JUST 
LEAVE THE CASTLE 
WHENEVER YOU WANT! 


re —- YOU FOLLOW ME 
YOU KNOW WHAT, CAIN? \\| 68 f BECAUSE IT’S YOUR 
YOU SHOULD JUST STAY \ee ATTENDANT'S JOB DUTY? 

IN THE CASTLE IF ALL ee 

YOU'RE GOING TO DO I THOUGHT YOU 


IS YELL AT ME! Al FOLLOWED ME 
BECAUSE YOU 
ARE MY FRIEND. 


OH, NO, I DIDN’T 
MEAN THAT...! 


I FOUND YOU, 
PRINCESS RURUNA!! 
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IT’S MY FAULT... 


NO, YOU DON'T 

RURUNA, YOU , : I CONVINCED 

HAVE GONE UNDERSTAND...tf PRINCESS RURUNA 
TOO FAR. TO LEAVE THE 


CASTLE...I! 


amhmmtl 


peas 


CAIN HAS TAKEN 
CARE OF ME... 


LET'S GO 
HOME, 
PRINCESS. 


SINCE I WAS 
A CHILD. 
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WHAT'S THE 


yylellicglus MATTER WITH 


MATTER WITH OH, NO, NO... 


=== 6) miu s | 
rr ~ Pr PS \ St ~ - 
aut, 2 RAINES ( \ vl HA, HA, HA : — - 
ge vo a 
eo ds i IN PREAMB ary 


RAMINESS!! we, 
Koy ae 


NEIGH, * | 
2 NEIGH 


OH NO, HE 
HOW ARE eae CAIN! LET'S GO IN 


YOU LOVELY THIS CAFE. 


LADIES? LET'S STUDY 


DATABASES HERE 
FOR A WHILE. 


HERE I AM! 


f] 


OH, A NEW 
PLACE TO 


THERE YOU 
ARE!! 


IT’S REFRESHING 
OUTSIDE. 


it 


: 


50, WE'VE GOTTEN 
TO THE POINT WHERE 
WE CAN DESIGN A 
DATABASE. 


YOU COULD 
SAY THAT. 


WHEN YOU USE THE 
DATABASE, YOU HAVE 
TO INPUT DATA OR 
RETRIEVE DATA, AS 
YOU ALREADY KNOW. 
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FINALLY... 


THE NEXT THING TO 
DO IS TO STUDY HOW Eieenoe oe 
TO USE THE DATABASE 
WE CREATED. 


TO DO THAT, 
WE'LL USE SQL. 


OUNDS 


ITS 
DIFFICULT... 


FOR EXAMPLE, IN THE SAME 
WHEN YOU HAVE A MANNER, YOU USE A 
CONVERSATION IN yoy LANGUAGE CALLED 

THE SWIMMY REGION ‘speak = STRUCTURED QUERY 


ACROSS THE SEA, = SWIMM LANGUAGE (SQL) 
LANGUAGE. 


YOU NEED TO ne TO HAVE A 


SPEAK SWIMMY CONVERSATION 
LANGUAGE. WITH A 


DATABASE. 


THE DATABASE DOES 
NOT REALLY SPEAK, 
YOU UNDERSTAND? 


[een | = 

eee 

ee ee 

Pos [ve [es] [as [te xmcnon oF eo | 
Zz 


(ee a [ore] 
[0s [tenon [2000 | 


SALES STATEMENT 
TABLE 


Seer) | 
[tor | ce | 300] 
[102 [es | 1700 
[es [oa [500 
[0 [ter | 2500 
[es [te [700 | 


YOU DESIGNED THESE 
KINDS OF TABLES 
THE OTHER DAY. 
REMEMBER? 
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BUT NOW, YOU NEED TO 
USE SQL TO PUT THESE FEATURES OF SQL 
TABLES AND DATA INTO THE & 
DATABASE. © CREATION OF TABLES 
© INPUT AND RETRIEVAL OF DATA 


e@ MANAGEMENT OF USERS 


BY USING SQL, YOU CAN ee ete ce 

HAVE A CONVERSATION A LOT OF WORK. 
WITH THE DATABASE TO DO 
TASKS LIKE THESE... 


IT SOUNDS LIKE WE 
CAN DO ALL SORTS 
OF THINGS!! 


WELL...THAT’S TRUE... I HAVE INPUT THE TABLES 
WE HAVE LEARNED AND I WANT TO USE A 


AND DATA WE DESIGNED 
50 MUCH DATABASE AS SOON EARLIER. 
ALREADY! AS POSSIBLE. 


LET'S RETRIEVE SOME 
DATA. 
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SEARCAING FOR Data YSING A SELECT STATEMENT 


JUST ASK THE 
WE NEED TO RETRIEVE DATABASE TO RETRIEVE 
ONLY PRODUCT NAMES TO THE PRODUCT NAME 
CREATE A PRODUCT NAME COLUMN... 
LIST USING SQL. 


FROM THE 
PRODUCT TABLE. 


HOW DO YOU DO ( MR. DATABASE... 
THAT? es z 


PLEASE RETRIEVE THE 
PRODUCT NAME COLUMN... 


YOU DON’T NEED TO 
PRAY! JUST USE SQL... 


YOU'D WRITE 
THIS: 


SELECT product_name 


FROM product; 


THIS SQL STATEMENT 
CONSISTS OF TWO 


IN SQL, ONE GROUPS OF WORDS: 
CONVERSATION IS CALLED) §=SELECT PRODUCT_NAME AND 
A STATEMENT. FROM PRODUCT. 
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PRODUCT TABLE 


fT 
peonver cove Peomucr wml] ww race | 
| 1) lmao || e006 | 
IN SQL, YOU SPECIFY A COLUMN | toz_—_|[etrawserry|| 1506 | 
NAME YOU WANT TO RETRIEVE 
WITH THE SELECT PHRASE AND THE | 13 |larne || 200 | 
TABLE NAME FROM WHICH YOU | 104 [Lemon |} zo0G | 


WANT TO RETRIEVE IT WITH THE 


FROM PHRASE. 


THESE GROUPS OF WORDS ARE 
CALLED PHRASES. 


HERE IS THE RETRIEVED 


THIS ALLOWS YOU TO 
RETRIEVE ALL PRODUCT 
es 
HERE YOU 9) 
a 


VARIOUS 


WE ARE HAVING A KINDS... WHAT ABOUT ASKING 
HMM. FOR A LIST OF 


CONVERSATION WITH A 
DATABASE USING SQL. Qe PRODUCTS WHOSE 
UNIT PRICE IS 
GREATER THAN OR 
EQUAL TO 2006? 


1 WELL 
wren Serve THEN, FOR GREATER 
NECESSARY EXAMPLE, 
DATA BY USING 
VARIOUS KINDS 
OF PHRASES. 
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IN SUCH CASES, YOU 
IN THAT CASE, YOU SPECIFY CONDITIONS 
DON’T WANT ALL THE WITH THE WHERE 
PRODUCT DATA. PHRASE. 
Ss { FOR EXAMPLE, 


YOU ONLY NEED 
TO RETRIEVE 
PRODUCTS WHOSE 
UNIT PRICE IS 
GREATER THAN OR 
EQUAL TO 2006. 


IT IS INCONVENIENT 
TO SPECIFY A 
COLUMN NAME &ACH NO PROBLEM! 
TIME, IDN’T IT? TO SPECIFY ALL 
COLUMNS, 


THIS STATEMENT 
RETRIEVES ALL THE DATA 


; HERE YOU 
YOU CAN USE *! YL i yy FROM THE PRODUCT 


ARE! 


IT CAN BE SUMMARIZED LL 
AS FOLLOWS. No TABLE... 2 ee 
SELECT * en 

FROM product - 

WHERE unit_price>=200 — 

THAT HAS A ee 

UNIT PRICE OF eae 


GREATER THAN OR 
EQUAL TO 2006. _/ 


50, IF YOU CHANGE NOW WE NEED TO ‘2 1 


THE CONDITIONS, LEARN HOW TO MAKE 
YOU CAN RETRIEVE CONDITIONS. 
PRODUCTS WHOSE 

UNIT PRICE IS BELOW 


WRITE IT LIKE THIS. WHEN 
~ USING CHARACTERS AS 


TO RETRIEVE APFLE, ; 
y THEM WITHIN QUOTATION 
FOR EXAMPLE? y é MARKS ('). 


OR 


: ) 
SELECT * PRODUCT | PRODUCT UNIT 
CODE NAME PRICE 
FROM product =p 
103 APPLE 1Z0G 


WHERE product_name='apple' ; 


IF YOU DO THIS, 
YOU CAN RETRIEVE 
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WHAT DO YOU 


WHAT ABOUT WHEN DO IN THAT 


YOU AREN’T SURE 
ABOUT THE PRODUCT 


ane 


YOU COMBINE THE 
WORD LIKE WITH A 
SYMBOL. 


EXPRESS THE UNKNOWN THIS WILL RETRIEVE 
PART USING %, LIKE THIS... \ PRODUCT NAMES THAT 
P END WITH VN. 


SELECT * PRODUCT PRODUCT UNIT 
e CODE NAME PRICE 


LEMON 2006 


WHERE product_name LIKE '%n'; 


MELON AND LEMON THAT'S CONVENIENT! 
ARE RETRIEVED LIKE 
THAT! 


ION’T IT? 
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USEING AGGREGATE FUNCTIONS 


TO SORT PRODUCTS IN YOU CAN FIND OUT 
phate alyEemcea tiie ORDER OF ASCENDING INFORMATION ABOUT 
PRICE, ADD A STATEMENT PRODUCTS BY DOING 


WITH AN ORDER BY 
LIKE ORDER BY UN/T 
PHRASE. PRICE. 


THAT'S 


rN A 
GREAT!! \ . Z 
oa . wo 
SELECT * SPO pail 
PRODUCT | PRODUCT UNIT 
FROM product CODE NAME PRICE 
ORDER BY unit_price; 


I WANT TO N= 
KNOW MORE : thy IM GLAD. 
ABOUT SQL, 


HOW ABOUT 
THIS ONE? 


IN THE SELECT PHRASE, USE ; 
AVG (COLUMN NAME) TO IT’S AMAZING. 
OBTAIN THE AVERAGE OF 

EACH ROW. 


SELECT AVG(unit_price) 


FROM product; 


WE NOW HAVE THE 
AVERAGE UNIT PRICE OF 
PRODUCTS. 


98 CHAPTER 4 


ERE ARE MANY THIN 
L DIDN'T KNOW THE) (eee ee vapour’ | | SQL ALSO HAS A 


AVERAGE FRUIT EVEN THOUGH THEY FUNCTION THAT 


PRICE WAS AT THIS ARE HAPPENING IN MY AGGREGATES THE 
COUNTRY. RETRIEVED DATA 


VALUES. 


ISNTIT | 
CONVENIENT? | 


50 YOU CAN GET 
DATA OTHER THAN THE 
AVERAGE VALUE? 


THE NUMBER OF ITEMS, 
SUM, AVERAGE, MAXIMUM 
VALUE, AND MINIMUM 
VALUE CAN BE OBTAINED 
BY SPECIFYING AN 
AGGREGATE FUNCTION. 


AGGREGATE FUNCTIONS IN SQL 


Function Description 

COUNT (*) Obtains the number of rows 

COUNT (column_name) Obtains the number of times the column is not null 
COUNT(DISTINCT column_name) Obtains the number of distinct values in the column 
SUM(column_name) Obtains the sum of the column's values in all rows 
AVG(column_name) Obtains the average of the column's values in all rows 
MAX(column_name) Obtains the maximum value of the column 
MIN(column_name) Obtains the minimum value of the column 


LIKE THIS... 
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WHAT DO YOU 
CAN I FIND HOW DO TO FIND THE 
MANY KINDS OF PRODUCT WITH THE 
FRUIT WE SELL? HIGHEST PRICE? 


SHOVE, f SHOVE, 
Ze. SHOVE... 
yy 


SQL ALLOWS YOU YOU CAN ALSO GROUP I UNDERSTAND. 
TO AGGREGATE DATA FOR FURTHER THE AGGREGATE 
DATA, SO YOU CAN MANIPULATION OR FUNCTIONS ARE 
FIND OUT LOTS OF § ANALYSIS. 
INFORMATION. “ 


WHAT ABOUT OUR LET'S CREATE A SALES 
SALES REPORT? REPORT USING SQL. 
THE STRANGE 
GLASSES AGAIN! 


Z 


A Se 
fl EEN 


q 
7 
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JOINING TABLES 


TO CREATE A SALES REPORT, 
YOU HAVE TO RETRIEVE DATA 
BY JOINING THE PRODUCT 
TABLE AND THE EXPORT 
DESTINATION, SALES, AND 
SALES STATEMENT TABLES. 


RIGHT. THERE 
WAS JUST ONE 
TABLE BEFORE 
NORMALIZATION. 


THE PRIMARY KEY IS EQUAL 
TO THE FOREIGN KEY 
WHICH REFERS TO THE 

PRIMARY KEY. 


IN ORDER TO JOIN 
TABLES, SQL REQUIRES 
A CONDITION THAT... 


HOW CAN YOU 
SPECIFY THAT? 


g | exroRt 
67 DESTINATION 


IF THE SAME COLUMN 
JOIN TABLES BY NAME APPEARS IN MULTIPLE 
PLACING A COMMA TABLES, JUST SPECIFY IT 
BETWEEN THEM. AS TABLE_NAME.COLUMN_ 
NAME. 


SELECT sales.report_code, date, sales.export_destination_ code, 
export_destination_ name, sales _statement.product_code, 
product_name, unit_price, quantity 


sales, sales statement, product, export_destination 


sales.report_code = sales statement.report_code 
AND HAVING JOINED 


THESE FOUR TABLES, 
sales _statement.product_code = product.product_code WE THEN RESTRICT 


AND OUR RESULTS USING 
export_destination.export_ destination code = WHERE. 
sales.export_destination_ code 
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THIS WAY, YOU CAN RETRIEVE 
SALES REPORT DATA FROM 
TABLES, EVEN IF THEY ARE 

DIVIDED. 


DEST. CODE | DEST. NAME CODE NAME PRICE 
were] er [mom [ome | wo 
= |= [ese 
de 
ve |= [pee 
Ter [oe [Pa 
rea 
— 


THIS IS THE SAME AS THE 
TABLE WE HAVE BEEN USING. 


WE RECREATED IT! 


THAT'S 
GREAT! 


wow! 


YOU CAN RETRIEVE DATA RELATING 
TO THE SALES REPORT EVEN IF 
YOU MANAGE PRODUCTS, EXPORT 
DESTINATIONS, AND SALES 
INDEPENDENTLY. 


N77 
NE a 


IN 


CREATING a ZABLE 


NOW I REMEMBER. 
YOU MADE THIS 
TABLE USING SQL, 
RIGHT TICO? 


CREATE TABLE product 


( 


product_code int NOT NULL, 
product_name varchar(255), 


unit price int, 


PRIMARY KEY(product_code) 


)5 


SO YOU HAVE 
ALREADY INPUT A 
TABLE AND DATA, 

RIGHT? 


YOU MUST SPECIFY THE 
PRIMARY KEY, AS WELL. 
I USED THE PRODUCT CODE 


AS A PRIMARY KEY. 


WE'VE ALSO SET THE 
DATATYPE OF EACH 
COLUMN. YOU CAN SEE 
THAT PRODUCT AND UNIT_ 


LIKE THIS... 


PRICE ARE INTEGERS (INT). 
VARCHAR MEANS THAT THE 


DATABASE EXPECTS TEXT, 
AND (255) LIMITS THE 
PRODUCT_NAME TO 255 


CHARACTERS. 


ld 
OLE 


* SEE PAGE 115 FOR A COMPLETE EXPLANATION OF CREATE TABLE STATEMENTS. 


HOW DID YOU 
MAKE IT? 


YOU USE A CREATE TABLE 
STATEMENT TO MAKE A 
TABLE. 


THIS PREVENTS YOU 
FROM ENTERING 
INCORRECT 
VALUES. 
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NOW WE CAN INPUT 
DATA IN THE TABLE WE 
CREATED, RIGHT? 


i} 
' 
1 
| 
' 
' 
' 
' 
+ 
! 
' 
| 
' 
| 
' 
+ 
| 
| 
| 
| 
1 
4 


INSERT INTO product (product_code,product_name,unit_price) 


VALUES (101, 'melon' , 800); 


MELON WAS INSERTED 
IN THE PRODUCT TABLE 
LIKE THIS. 
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YOU USE AN INSERT 
STATEMENT TO ADD 


DATA. 


YOU CAN ALSO DELETE 
(DELETE STATEMENT) 
AND UPDATE (UPDATE 

STATEMENT) THE DATA. 


AND THE UNIT PRICE 
OF A PRODUCT CAN 
BE CORRECTED 
USING SQL. 


YOU MAY BE ABLE SELECT STATEMENTS 

TO MANAGE FRUIT ARE THE MOST 

EXPORTS USING A IMPORTANT PART OF 
DATABASE. A SQL. S50 STUDY HARD. 


Ss 
Ss 


hI 
fi 
bs 
4) 
YES | 


Y IF YOU CAN FULLY 
UTILIZE SQL, YOU 
MAY BE ABLE 
TO MANAGE 
DATABASES... 


OH DEAR, LOOK 
AT THE TIME! 


LET'S GO BACK 
TO THE CASTLE 
BEFORE IT GETS 
DARK, 


OR ELSE I'LL GET 
YELLED AT BY GUARD 
CAPTAIN IGOR AGAIN. 


THAT OLD 
BULLY... 


CAIN!! 


HURRY UP, I’M 
LEAVING. 


SQL OVERVIEW 


In this chapter, Princess Ruruna and Cain learned about SQL, or Structured Query Lan- 
guage, a language used to operate a relational database. SQL’s commands can be broken 
down into three distinct types: 


Data Definition Language (DDL) Creates a table 


Data Manipulation Language (DML) Inputs and retrieves data 
Data Control Language (DCL) Manages user access 


SQL has commands that create the framework of a database, and a command that 
creates a table within a database. You can use this language to change and delete a table 
as well. The database language that has these functions is called the Data Definition Lan- 
guage (DDL). 

SQL also has commands that manipulate data in a database, such as inserting, 
deleting, and updating data. It also has a command that allows you to search for data. The 
database language with these functions is called the Data Manipulation Language (DML). 

In addition, SQL offers the capability to control a database, so that data conflicts will not 
occur even if multiple people use the database at the same time. The database language 
associated with these functions is called the Data Control Language (DCL). 


SEARCAING FOR Data SING a SELECT STATEMENT 


Princess Ruruna and Cain started learning SQL by using a basic data search function. SQL 
searches for data when one statement (a combination of phrases) is input. To search for a 
certain product with a unit price of 200G, for example, you would use the following SQL 
statement. 


SELECT * 
Create an SQL statement 
FROM product ee 
: . by combining phrases. 
WHERE unit_price=200 


A SELECT statement is the most basic SQL statement. It specifies which column, from 
which table (FROM), and matching which conditions (WHERE). You can combine these 
phrases to make intuitive, query-type statements in SQL—even a user unfamiliar with 
databases can use them to search for data. 


106 CHAPTER 4 


CREATING 


CONDITIONS 


Cain said earlier, “Now we need to learn how to make conditions.” Let's look at some ways to 


create conditions using SQL. 


COMPARISON OPERATORS 


One way to express conditions is by using comparison operators like >= and =. For example, 
the condition “A is greater than or equal to B” is expressed using >=, and the condition “A is 
equal to B” is expressed using =. More examples of comparison operators are shown in the 


table below. 


COMPARISON OPERATORS 


Comparison 
operator 


A=B 
A>B 
A>=B 


A<B 
A<=B 


AoB 


Description 


A is equal to B. 
A is greater than B. 


A is greater than or equal 
to B. 


Ais less than B. 


A is less than or equal 
to B. 


A is not equal to B. 


Example 


unit_price=200 
unit_price>200 


unit_price>=200 


unit_price<200 


unit_price<=200 


unit_price<>200 


LOGICAL OPERATORS 


In some cases, you need to express conditions that are more complex than simple com- 
parisons. You can use logical operators (AND, OR, and NOT) to combine operator-based 
conditions and create more complicated conditions, as shown in the table below. 


LOGICAL OPERATORS 


Logical operator 
AND 


OR 


NOT 


Description Example 


AandB Product code >= 200 
AND unit price = 100 

AorB Product code >= 200 
OR unit price = 100 

Not A NOT unit price = 100 


Description of example 


Cc 
= 


it price is 200G. 
Unit price is greater than 2006. 


Cc 
=| 


it price is greater than or equal to 
2006. 


Unit price is less than 2006. 
Unit price is less than or equal to 2006. 


Unit price is not 2006. 


Description of example 


The product code is greater than or equal 
to 200 and the unit price is 1006. 


The product code is greater than or equal 
to 200 or the unit price is 1006. 


The unit price is not 1006. 
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PATTERNS 


When you don’t know exactly what to search for, you can also use pattern matching in 
conditions by using wildcard characters. When using pattern matching, use characters such 
as % or_ in a LIKE statement; this will search for a character string that matches the pattern 
you specify. You can search for a value that corresponds to a partially specified character 
string using %, which indicates a character string of any length, and _, which specifies only 
one character. 

An example of a query using wild cards is shown below. This example statement 
searches for a character string that has n at the end of the product name. 


SELECT * 
FROM product This statement matches 8006 
WHERE product_name LIKE '%n'; patterns using a wild card. 2006 


The wild cards you can use in an SQL statement are explained below. 


WILD CARDS 
Wild Description Example of Matching character 
card pattern string 
% Matches any number of an Lemon Melon 
characters n% Nut Navel orange 
= Matches one character ae it 
L. to 
SEARCHES 


There are also many other search methods. For example, you can specify BETWEEN X AND 
Y for a value range. If you specify a range as shown below, you can extract products with 
unit prices greater than or equal to 150G or less than 2006. 


SELECT * 
FROM product 
WHERE unit_price 


BETWEEN 150 AND 200; Specifies a search range 


In addition, you can specify IS NULL when searching for rows. If you use the search 
shown below, you can extract products with null unit prices. 


SELECT * 
FROM product 


WHERE unit_price is NULL; Searches for a null 
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QUESTIONS 


Now, let’s create SQL statements using various kinds of conditions. Let’s use the Export 
Destination Table below (assuming the unit for population is 10,000). Answer the questions 
below using SQL statements. The answers are on page 119. 


EXPORT DESTINATION TABLE 


Export destination code Export destination name Population 
sl The Kingdom of Minanmi 100s 


Sf z 


2 
23 
z 
[0 _____[ The kingdom of Sazanna[ 80 | 


Qi 
To find countries in which the population is greater than or equal to 1 million, extract 
the table below. 


[os SSS~*diha me 20S 
50 


2 
23 
25 


Q2 
To find countries in which the population is less than 1 million, extract the table below. 


Export destination code Export destination name Population 


Q3 
Find countries in which the export destination code is less than 20 and the population 
is greater than or equal to 1 million. 


Q4 
Find countries in which the export destination code is greater than or equal to 30 and 
the population is greater than 1 million. 


Qs 
What is the population of the Kingdom of Ritol? 


Q6 
Find countries whose names contain the letter n. 
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AGGREGATE FUNCTIONS 


Princess Ruruna and Cain have learned about various aggregate functions. Aggregate 
functions are also known as set functions. You can use these functions to aggregate infor- 
mation such as maximum and minimum values, number of items, and sum. 

If you specify a WHERE phrase along with an aggregate function, you can obtain an 
aggregated value for just the specified rows. If you specify a phrase like the one shown 
below, you can figure out the number of products with unit prices greater than or equal to 


2006. 
SELECT COUNT(*) 
COUNT (* 
FROM product 
WHERE unit_price>=200; 2 


AGGREGATING DATA BY GROUPING 


If you group data, you can obtain aggregated values easily. For example, if you want to 
obtain the number of products and average unit price based on district, you can use the 
grouping function. 

To group data, combine the aggregate function and the GROUP BY phrase. Let’s use 
the Product Table shown below. 


PRODUCT TABLE 


To obtain the average unit price for each district in the Product Table, specify the 
District column and the AVG function for the GROUP BY phrase. This will group data based 
on district and give you the average unit value of the products in each district. 


AVG(unit_price) 
SELECT district,AVG(unit_price) 


FROM product South Sea | 332.5 


GROUP BY district; Enables grouping | |North Sea | 110 
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What if you wanted to further restrict your results, based on a particular property of 
the data? Assume that you want to find products with regional average unit prices greater 
than or equal to 2006. In this case, do not specify a condition in the WHERE phrase, but use 
a HAVING phrase instead. This allows you to extract only districts in which the average unit 
price is greater than or equal to 2006. 


SELECT district, AVG(unit_price) 


FROM product AVG(unit_price) 
GROUP BY district; Filters results 332.5 


HAVING AVG(unit_price)>=200; after being grouped 


QUESTIONS 


Answer the questions below using this Export Destination Table (assuming the unit for 
population is 10,000). The answers are on page 120. 


EXPORT DESTINATION TABLE 


Export destination code | Export destination name Population | District 
The Kingdom of Minanmi South Sea 


Middle 
North Sea 
North Sea 
South Sea 
| go South Sea 
North Sea 
300 


Q7 


What is the smallest population? 


Qs 
What is the largest population? 


Qo 
What is the total population of all countries included in the Export Destination Table? 


Qio 
What is the total population of the countries in which the export destination code is 
greater than 20? 


qQi1 
How many countries are there in which the population is greater than or equal to 
1 million? 


Qi2 
How many countries are in the North Sea district? 
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Qi3 
Which country in the North Sea district has the largest population? 


Q14 
What is the total population of every country excluding the Kingdom of Ritol? 


qi5 
Find the districts in which the average population is greater than or equal to 2 million. 


Q16 
Find the districts that contain at least three countries. 


SEARCAING FOR Data 


There are more complicated query methods available in SQL, in addition to the ones we've 
already discussed. 


USING A SUBQUERY 


For example, you can embed one query in another query. This is called a subquery. Let's 
look at the tables below. 


PRODUCT TABLE SALES STATEMENT TABLE 


Product Product Unit price Report Product Quantity 
code name code code 
101 8006 1101 101 1,100 

102 1506 1101 102 300 


103 1206 1102 103 1,700 


104 2006 1103 104 500 
1104 101 2,500 
1105 103 2,000 


1105 104 700 


You can use these two tables to search for the names of products for which the sales 
volume is greater than or equal to 1,000. The following SQL statement will conduct that 
search. 


SELECT * FROM product 
WHERE product_code IN 
(SELECT product_code 


FROM sales statement This statement contains a subquery. 


WHERE quantity>=1000) ; 
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In this SQL statement, the SELECT statement in parentheses is performed first: The 
product code in the Sales Statement Table is searched for first, and product codes 101 
and 103 are found (as these are the only reports with sales volume greater than 1,000). 
These product codes are used as a part of the condition for the SELECT statement outside 
the parentheses. For IN, the condition is satisfied when a row matches any value enclosed 
within parentheses. Thus, products that correspond to the product codes 101 and 103 will 
be returned. 

In other words, in the case of a subquery, the result of the SELECT statement within 
parentheses will be sent to the other SELECT statement for searching. The following infor- 
mation will be the result of the whole query. 


USING A CORRELATED SUBQUERY 


Let's consider a subquery as being contained inside another query. Such a subquery 
may refer to data from the outer query. This is called a correlated subquery. In the query 
below, the sales statement table in the outer query is temporarily given the new name U 
so the subquery can refer to it unambiguously. The syntax U. product_code indicates which 
product_code column is intended, since there are two sources for that column inside the 
subquery. 

Because the subquery refers to data from the outer query, the subquery is not inde- 
pendent of the outer query as in previous examples. This dependency is called a correlation. 


SELECT * 


FROM sales statement U 
WHERE quantity> 
(SELECT AVG(quantity) 


FROM sales_statement 
WHERE product_code=U.product_code) ; 


This query extracts 


1104 101 2,500 sales volume greater 
[2500 than the product’s 

1105 103 2,000 average. 

1105 104 700 


Let's look at how this correlated subquery is processed. In the correlated subquery, the 
query outside is implemented first. 


SELECT * 
FROM sales statement U 


This result is sent to the query inside to be evaluated row by row. Let's explore the 
evaluation of the first row, product code 101. 
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(SELECT AVG(quantity) 
FROM sales statement 


WHERE product_code=101) 


The product code for the first row is 101, or melons—the average sales quantity of 
melons is 1,800. This result is then sent as a condition for the query outside. 


@ | WHERE quantity>(1,800) 


This process continues for all rows in the sales statement—steps @ and ® are per- 
formed for all possible product codes. In other words, this query extracts reports in which 
the sales volume of a fruit is greater than that particular fruit’s average sales quantity. 
Consequently, only the fifth, sixth, and seventh rows of @ are extracted. 


QUESTIONS 


Now, answer the following questions based on the Product Table and the Sales Statement 
Table. The answers are on page 122. 


Q17 
Find the sales statement for fruit with unit prices greater than or equal to 300G, and 
extract the table below. 


Report code Product code 


1101 101 1,100 
1104 101 2,500 


Qi8 
Obtain the average sales volume by product, and find iterns that have sales volumes 
that are less than the average. 


JOINING TABLES 


After conducting an SQL-based search, Princess Ruruna and Cain created a sales report by 
combining tables. Joining tables by combining columns with the same names is called an 
equi join. For an equi join, rows with the same value are designated as join conditions for 
joining tables. Joining columns with the same name into one is called a natural join. 
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The join method in which only rows having a common value like equi join are selected 
is called inner join. 

In contrast, the join method that keeps all rows of one table and specifies a null for 
rows not included in another table is called an outer join. If you place a table created from 
an outer join on the right or left of an SQL statement, it is called a left outer join or a right 
outer join, depending on which rows are kept. 


Left table Right table 


Left Right 
outer join outer join 


CREATING A ZABLE 


Finally, Princess Ruruna and Cain learned about the statement syntax that creates a table, 
CREATE TABLE. The statement syntax inside a CREATE TABLE statement often depends on 
the particular kind of database you use. An example is shown below. 


CREATE TABLE product This statement creates a table. 


( 


product_code int NOT NULL, 
product_name varchar(255), 
unit_price int, 

PRIMARY KEY(product_code) 
)s 


When you create a table, you must specify its column names. Additionally, you can 
specify a primary key and a foreign key for each column. In this example, the product code 
is specified as a PRIMARY KEY and product code is not allowed to be null. When creating a 
table, you may need to include the following specifications. 
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CONSTRAINTS ON A TABLE 


Constraint Description 

PRIMARY KEY Sets a primary key 

UNIQUE Should be unique 

NOT NULL Does not accept a NULL value 
CHECK Checks a range 

DEFAULT Sets a default value 


FOREIGN KEY REFERENCES Sets a foreign key 


These specifications are called constraints. Giving constraints when creating a table 
helps to prevent data conflicts later on and allows you to correctly manage the database. 


INSERTING, UPDATING, OR DELETING ROWS 


You can use the INSERT, UPDATE, and DELETE statements to insert, update, or delete data 
from a table created by the CREATE TABLE statement. Let’s insert, update, and delete some 
data using SQL. 


INSERT INTO product 
(product_code, product_name, unit_price) 
VALUES (200, ‘cherry’ ,200); 


This statement adds cherry. 


UPDATE product This statement updates 
SET product_name='cantaloupe' melon to cantaloupe. 


WHERE product_name='melon' ; 


DELETE FROM product 


This statement deletes apple. 
WHERE product_name='apple' ; 


Product name 
Apple 1206 
104 
200 


Updated to cantaloupe. 


Apple is deleted. 


00 | 


When inserting, updating, or deleting a row, you cannot violate the constraints set by 
the CREATE TABLE statement. If a product with product code 200 already exists, you cannot 
add cherry, since you cannot add duplicated data as a primary key. When you insert, update, 
or delete data in a database, you must consider the database's constraints. 


Cherry Cherry is added. 
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CREATING A VIEW 


Based on the table you created with the CREATE TABLE statement, you can also create a 
virtual table that exists only when it is viewed by a user. This is called a view. The table from 
which a view is derived is called a base table. 


View Base table 


Use the SQL statement shown below to create a view. 


CREATE VIEW expensive_product This statement creates a view. 
(product_code, product_name,unit_price) 
AS SELECT * 

FROM product 

WHERE unit_price>=200; 


The Expensive Product Table is a view based on the Product Table, which is a base 
table. It was created by extracting data with unit prices greater than or equal to 200G from 
the Product Table. 


EXPENSIVE PRODUCT TABLE 


Once you create the Expensive Product view, you can search for data in it the same way 
you would search for data in a base table. 


SELECT * Allows the view to be used 
FROM expensive product in the same manner as a 
WHERE unit_price>=500; base table 


It is convenient to create a view when you want to make part of the data in a base 
table public. 
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There are also SQL statements for deleting a base table or view. The statement used to 
delete a base table or view is shown below. 


DROP VIEW expensive product; 


DROP TABLE product; 


QUESTIONS 


Create SQL statements for the following questions (assuming the unit for population is 
10,000). The answers are on page 123. 


qi9 
The following Export Destination Table was created using a CREATE TABLE statement. 
Add the data below. 


EXPORT DESTINATION TABLE 


Export destination name _ | Population District 


The Kingdom of Minanmi 100 South Sea 


The Kingdom of Tokanta 160 North Sea 


The Kingdom of Paronu 200 Middle 
Alpha Empire 120 


Q20 
From the Export Destination Table in Q19, create a view titled North Sea Country that 
shows countries belonging to the North Sea district. 


EXPORT DESTINATION TABLE 


Export destination name | Population 


The Kingdom of Tokanta 160 
Alpha Empire 120 


Q21 
Change the population of the Kingdom of Tokanta in the Export Destination Table to 
1.5 million. 


Q22 
In the Export Destination Table, delete all data for the Kingdom of Paronu. 


SUMMARY 


* — You can use SQL functions to define, operate, and control data. 

* To search for data, use a SELECT statement. 

* To specify a condition, use a WHERE phrase. 

* To insert, update, and delete data, use INSERT, UPDATE, and DELETE statements. 
* To create a table, use a CREATE TABLE statement. 


ANSWERS 


Qi 


SELECT * 
FROM export_destination 
WHERE population>=100; 


Q2 


SELECT * 
FROM export_destination 
WHERE population<100; 


Q3 


SELECT * 

FROM export_destination 

WHERE export_destination_code<20 
AND population>=100; 


The Kingdom of Minanmi 100 


Q4 


SELECT * 

FROM export_destination 

WHERE export_destination_code>=30 
AND population>100; 


None of the countries meet this criteria, so this query returns an empty set. 
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Qs 


Q6 


Q7 


Q8 


Q9 


SELECT population 
FROM export_destination 
WHERE export_destination_name='the Kingdom of Ritol'; 


Population 


150 


SELECT * 
FROM export_destination 
WHERE export_destination_ name LIKE '%n%'; 


Export destination code | Export destination name _ | Population 
12 The Kingdom of Minanmi 


25 The Kingdom of Ritol 
30 The Kingdom of Sazanna | 30 


SELECT MIN(population) 
FROM export_destination; 


MIN(population) 


SELECT MAX(population) 
FROM export_destination; 


MAX(population) 


300 


SELECT SUM(population) 
FROM export_destination; 


SUM(population) 
1,350 


Q10 


SELECT SUM(population) 
FROM export_destination 
WHERE export_destination_code>20; 


SUM(population) 
1,050 


Qi1 
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FROM export_destination 
WHERE population>=100; 


COUNT(*) 


; 


Q12 


SELECT COUNT(*) 
FROM export_destination 
WHERE district='north sea'; 


COUNT(*) 


; 


Q13 


SELECT MAX(population) 
FROM export_destination 
WHERE district='north sea'; 


MAX(population) 
240 
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SELECT SUM(population) 
FROM export_destination 
WHERE NOT(export_destination_name='the Kingdom of Ritol'); 


SUM(population) 
1,200 


Q15 


SELECT district, AVG(population) 
FROM export_destination 

GROUP BY district 

HAVING AVG(population)>=200; 


Middle 250 


Q16 


SELECT district, COUNT(*) 
FROM export_destination 
GROUP BY district 

HAVING COUNT(*)>=3; 


COUNTED 


Q17 


SELECT * 

FROM sales statement 
WHERE product_code IN 
(SELECT product_code 
FROM product 

WHERE unit_price>=300); 
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SELECT * 

FROM sales statement U 

WHERE quantity< 

(SELECT AVG(quantity) 

FROM sales statement 

WHERE product_code=U.product_code) ; 


Qi9 


INSERT INTO export_destination(export_destination_ 
code,export_destination_ name, population, district) 
VALUES(12,'the Kingdom of Minanmi',100, ‘south sea'); 
INSERT INTO export_destination(export_destination_ 
code,export_destination_ name, population, district) 
VALUES(15,'the Kingdom of Paronu',200, 'middle'); 
INSERT INTO export_destination(export_destination_ 
code,export_destination_ name, population, district) 
VALUES(22,'the Kingdom of Tokanta',160, ‘north sea'); 
INSERT INTO export_destination(export_destination_ 
code,export_destination_name, population, district) 
VALUES(23, ‘Alpha Empire',120,'north sea'); 


Q20 


CREATE VIEW north _sea_country(export_destination_ 
code,export_destination_name, population) 

AS SELECT export_destination_code,export_destination_name, population 
FROM export_destination_name 

WHERE district='north sea'; 


Q21 


UPDATE export_destination 
SET population=150 
WHERE export_destination_name='the Kingdom of Tokanta' ; 


Q22 


DELETE FROM export_destination 
WHERE export_destination_name='the Kingdom of Paronu' ; 
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STANDARDIZATION OF SQL 


SQL is standardized by the International Organization for Standardization (ISO). | 
Japan, it is standardized by JIS (Japanese Industrial Standards). 
Other SQL standards include SQL92, established in 1992, and SQL99, established 


in 1999. Relational database products are designed so that queries can be made in 
accordance with these standards. 

Some relational database products have their own specifications. Refer to the 
operation manual for your database product for further information. 


o 


LET'S OPERATE A DataBase’ 


‘i 
CEE 


CLICK, CLICK, 
CLICK... 


Tae Li 
EL Lief 
Lied 


CZ 


a eel 
| EW i ! 
©) 

f 


al 

UY 
rs CLICK, CLACK, 
| y 


YOU SEE, THIS ONE 
AND THIS ONE ARE 
NEW ORDERS. 


YES, SIR. LL ADD 
THEM TO THE 
DATABASE RIGHT 
AWAY. 


ARGH, SHOW UP 
WE'RE FINALLY NORMALLY, WILL 
LEARNING TO USE A 
DATABASE, AREN’T WE? 


SORRY 
"BOUT THAT. 
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Whac /5 a TRANSACTION? 


ACTUALLY, FOR EXAMPLE, I WONDER 


I SHOULD BUT WE STILL WHY A DATABASE CAN STILL 
THANK YOU... HAVE SO MUCH OPERATE WHEN SO MANY 
TO LEARN. USERS ARE ACCESSING IT AT 
THE SAME TIME. 


FOR THAT MATTER, 
THE ISSUE OF 
SECURITY ALSO 
CONCERNS ME A 


TO BETTER 
UNDERSTAND 
THE ISSUES, 


APPARENTLY, YOU HAVE 
SOME WORRIES ABOUT 
YOUR DATABASE. 


I HAVE DONE 
A LITTLE 
RESEARCH. 


THE TITLE OF MY 
PRESENTATION IS: 


HOW CAN A DATABASE 
LET A LARGE NUMBER 
OF USERS ACCESS IT 
SIMULTANEOUSLY? 


I HAVE EVEN 
PREPARED 
ILLUSTRATIONS 
TO HELP YOUR 

UNDERSTANDING! 


y ‘ia ’ 


G DATABASE =| 
THEATER 
S B 


I LOVE A GOOD 
SHOW! 


NOW LET ME BEGIN. ONE DAY, ANDY 
AND BECKY 
ACCESSED THE 
DATABASE AT THE 
SAME TIME. 


FROM THIS DATABASE, ANDY 
READ THE PRODUCT TABLE, 
NAMELY APPLES. 


1 SEE 30 
NOW. 


HE THEN ADDED 10 TO THE 
INVENTORY BY WRITING A 
DATABASE OPERATION. 


MEANWHILE, BECKY ALSO READ 
THE NUMBER OF APPLES, 30, 
AND ADDED 10 HERSELF. 


a : 
BUT AFTER THAT OPERATION, (_SEt App.) i Ebaer io) 


THE DATABASE SHOWS ° TY 8 


THE CURRENT NUMBER OF /\ Have R 
APPLES AS 40. TLL Have \ fF an 
AO, THEN. : : 


OS (s) O Wnt 


40 
APPLES 
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SHOULDN'T IT 
BE 50 NOW? 


ANDY HAS 
ADDED 10. 
BECKY HAS 
ADDED 10. 


EATEN UP. 
BY CAIN! 


IN FACT, IN THIS 
SEQUENCE, BECKY CAN’T 
PERFORM ANY DATABASE 
OPERATION WHILE ANDY’S 

WORKING. 


IN ORDER TO ALLOW 
ANDY AND BECKY TO 
USE THE DATABASE AT 
THE SAME TIME, 


THERE MUST BE A 
MECHANISM TO PREVENT 
INCONSISTENCIES AND 
DUPLICATIONS SUCH AS 
THIS. 


50 WHERE HAVE 
THE 10 APPLES 


NO WAY! THEY 
WEREN'T THERE TO 
BEGIN WITH! 


50 10 APPLES 
WOULD NEVER 
DISAPPEAR. 


50 THE QUESTION IS, HOW 
DOES A DATABASE CONTROL 
USER OPERATIONS? 


I'LL EXPLAIN THAT NOW! 


GROOVY! 


CAIN’S 
TERRIFIC 
TODAY. 


\ 


FIRST OF ALL, A UNIT OF DATA OPERATIONS IS 
A DATABASE IS —— CALLED A TRANSACTION. 
DESIGNED TO 
PROCESS DATA 

OPERATIONS IN A 


IN THIS EXAMPLE, A 
READ OPERATION, AN 
ADD OPERATION, AND A 
WRITE OPERATION ARE 
PROCESSED AS A SINGLE 
TRANSACTION. 


TRANSACTION 
NOILLDVSNVAL 


50, ANDY'S AND BECKY'S 
OPERATIONS FORM OPERATIONS FORM 
ONE TRANSACTION, ANOTHER. 
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Whac /5 a LOCK? 


IN A DATABASE, WHEN THEY 
OPERATIONS BY ACCESS THE 
MANY USERS ARE 
CONTROLLED SO 


FOR THAT PURPOSE, A 
DATABASE ee, alee A LOCK 
CONCURRENTLY. : 
THAT NOTHING GOES 


YOU MEAN “LOCK” AS 
IN “LOCK AND KEY”? 


6 


LET ME EXPLAIN 
USING THE PREVIOUS 
YOU LOCK DATA TO } EXAMPLE. 
PREVENT IT FROM ‘ 
BEING ERRONEOUSLY 
PROCESSED. 
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ANDY LOCKS THE DATA BEFORE WHEN BECKY TRIES TO PERFORM HER 
PERFORMING A SERIES OF OPERATIONS, SHE MUST WAIT UNTIL 
OPERATIONS. ANDY |S FINISHED. 


| 30 
APPLES 
APPLES 


Kg 


B I’M 
WAITING IN 


A QUEUE! 
WAITING FOR ANDY TO 
FINISH PROCESSING. 
SE enacted 


BECKY CAN ONLY PERFORM 
HER OPERATIONS AFTER 
ANDY IS THROUGH WITH HIS 
OPERATIONS. 


AS A RESULT, THE DATABASE 
YIELDS THE VALUE 50, AS IT 
SHOULD. 


OH, BOY! CAIN, 
I’M IMPRESSED. 


YEAH, YEAH. 
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DATABASE 


THAT FINALIZATION IS 
CALLED A COMMIT 
OPERATION. 


50, I UNDERSTAND THAT 
OPERATIONS ON THE 
DATABASE ARE FINALIZED 
WHEN EACH TRANSACTION 
IS PROCESSED 
CORRECTLY. 


50 WE USE DIFFERENT 
ALTHOUGH A LOCK HAS ITS TYPES OF LOCKS 


OWN ROLE IN A DATABASE, DEPENDING ON THE 
LOCKING SHOULD NOT SITUATION. 
BE OVERUSED. IT CAN 
HINDER THE PURPOSE OF A 
DATABASE: SHARING DATA 
WITH A LOT OF PEOPLE. 


BUT CANNOT 
WHILE A SHARED LOCK PERFORM 
IS APPLIED, OTHER USERS A WRITE 
CAN READ THE DATA... OPERATION 


FOR EXAMPLE, YOU CAN 
USE A SHARED LOCK 
FOR A READ OPERATION 
WHEN IT IS THE ONLY 
OPERATION NEEDED. 


SHARED 
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WHEN PERFORMING 

A WRITE OPERATION, 

A USER APPLIES AN 
EXCLUSIVE LOCK. 


I SEE THAT THERE 
ARE DIFFERENT 
TYPES OF LOCKS. 


IN A DATABASE, 
CONCURRENCY 
CONTROL ALLOWS 
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WHEN AN EXCLUSIVE 
LOCK IS APPLIED, 
OTHER USERS CANNOT 
READ OR WRITE DATA. 


WHEN A LOCK IS USED TO 
CONTROL TWO OR MORE 
TRANSACTIONS, THAT IS CALLED 
CONCURRENCY CONTROL. 


AS MANY USERS AS 
POSSIBLE TO USE A 
DATABASE AT ONE TIME 
WHILE PREVENTING 
DATA CONFLICTS FROM 
OCCURRING. 


IS THAT ISN'T HE 
YOU MUST HAVE YOUR DEPENDABLE, 
STUDIED A LOT! 


IMPRESSION? RURUNA? 


AV 


KS 
N 


Bi. ae 
NO, NOT REALLY. ee fy 


Maen IN SOME CASES, CONCURRENCY 
Segoe CONTROL WITH A LOCK MAY CAUSE 
A PROBLEM. 


TOPIC. 


AND SUPPOSE BECKY 
HAS APPLIED AN 
EXCLUSIVE LOCK ON 
THE STRAWBERRY 
DATA. 


SUPPOSE ANDY HAS 
APPLIED AN EXCLUSIVE 
LOCK ON THE APPLE 
DATA. 


Caen aaa aaa 


ok) 


LLL 


STRAWBERRY DATA 


NEXT, ANDY MAY AND BECKY MAY WHAT WOULD 
TRY TO APPLY AN TRY TO APPLY AN HAPPEN THEN? 
EXCLUSIVE LOCK ON EXCLUSIVE LOCK 
STRAWBERRY DATA, ON APPLE DATA. 


SINCE EACH OF THEM NEITHER ONE CAN 
MUST WAIT FOR THE PROCEED WITH THEy ACT 70 rin) 
THING, 


LOCK APPLIED BY THE ANY OPERATION. Hi 
OTHER USER TO BE IS THAT IT? 


RELEASED, 


THIS SITUATION, 
WHICH IS CALLED FOR EXAMPLE, YOU Gor 
A DEADLOCK, CAN LOOK FOR WHEN YOU cANcEL (i) 
CANNOT BE TRANSACTIONS THAT A TRANSACTION, 
SOLVED UNLESS HAVE BEEN QUEVED IT’S CALLED A 
ONE OF THE FOR A CERTAIN LENGTH ROLLBACK. 
LOCKS |S OF TIME... 
RELEASED. 


AND CANCEL THEM! ROLLBACK? 
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YOU MEAN YOU CAN a YES! FOR EXAMPLE, IF A 
CANCEL ALL THE (3) TRANSACTION TO “DISCOUNT FRUITS 
OPERATIONS IN A 7] 2 PRICED LESS THAN OR EQUAL TO 
TRANSACTION AT P 1506” HAS FAILED, 


OPERATIONS FOR APPLES AND 
STRAWBERRIES MUST BE CANCELED 
ALTOGETHER, RIGHT? 


aN 


SO THE DATABASE 
BEHAVES AS IF NO IF ANYTHING HAS 
OPERATION HAD OCCURRED DURING 
BEEN PERFORMED : A TRANSACTION TO 
AT ALL? DISABLE FINALIZATION, 


[commit r 


THEN A ROLLBACK 
IS PERFORMED 


INSTEAD OF 
A COMMIT 
OPERATION. 


OPERATION 


ALL RIGHT! 


; NOW, TICO, 
THAT'S RIGHT. DEAR, THE NEXT 
A TRANSACTION ALWAYS a | TOPIC IS. 
ENDS WITH A COMMIT OR ' f “ 
ROLLBACK OPERATION. r 


THERE ARE NO HALF MEASURES, 
IN OTHER WORDS. 
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DacaBasé SECURITY 


I SEE. 

EVEN WHEN IT’S SHARED 
AMONG A LOT OF PEOPLE 
CONCURRENTLY, A DATABASE 
CAN AVOID TROUBLE IF IT’S 
DESIGNED CORRECTLY. 


RAMINESS! OUT 
OF THE BLUE! 


RAMINESS SHOWS 
UP LIKE THE WIND. 


I’M THE ONE THAT 


WHA EY 
Lata nation SHOULD BE ANGRY. 


DOING HERE?! 


DON’T BE 50 
UPSET. 


OUR PRODUCT 


ee 


WHAT’S WRONG spa, THE PRICES. 
WITH IT? i(~ Xp THE PRICES! 


THE FIGURES 
IN THE UNIT PRICE 
COLUMN ARE ALL 

MESSED UP! 


aa PRAGA ARTET EAE, 
“ae py 
mall 

i 


ees Pe 
i f TE 
: 


BECAUSE YOUR INVOICES 
ARE SUCH A MESS, MY 
COUNTRY, AN IMPORTER, IS 
EXPERIENCING HAVOC. 


WHY DON’T YOU ACCEPT MY 
PROPOSAL, PRINCESS RURUNA? 
COME OVER TO MY COUNTRY 
AND BE MY BRIDE. 


A DATABASE |S A 
NASTY THING. 


AS PART OF THE 
COMPENSATION FOR 
THIS TROUBLE... 


i . 
t ( 


( , 
tate 


PRINCE RAMINESS, 


SOMEONE WITH 
MALICIOUS INTENT MIGHT 
HAVE PERFORMED AN 
UNAUTHORIZED DATA 
OVERWRITE. 


WE ARE VERY 
SORRY. 
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WE PROMISE TO TAKE 
ACTION FOR DATABASE 
PROTECTION TO PREVENT 
THIS KIND OF THING FROM 
HAPPENING AGAIN. 


FORGIVE US ill 
FOR THIS, WON'T < YOU SAY YOU'LL FIX IT, 
r {|  BUT...I/M NOT SO SURE.... 
BE MORE SPECIFIC, 
WILL YOU? 


THE CAUSE OF THIS 
TROUBLE |S THAT FIRST OF ALL, WE WILL 
EVERYBODY IN THE HAVE SET UP ACCESS 
KINGDOM OF KOD HAS CONTROL TO LIMIT USERS 
FREE ACCESS TO THE OF THE DATABASE. 
DATABASE. 


SECOND, WE 
A GOOD SOLUTION MAY BE WILL CONFIGURE 


TO REQUIRE USERNAMES AND 
PASSWORDS TO ACCESS THE ee ee 
DATABASE, TO CONFIRM THAT CERTAIN OPERATIONS 
EACH USER IS TRUSTWORTHY ONLY TO AUTHORIZED 
ENOUGH TO BE GIVEN 
ACCESS RIGHTS. 


SOUNDS 
CLEVER! 
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- MERCHANDISE DEPARTMENT PERSONNEL MAY SEARCH, INSERT, UPDATE, AND DELETE PRODUCT DATA. 
ne 


PULL, 


QQ | 


OVERSEAS BUSINESS DEPARTMENT PERSONNEL MAY SEARCH AND INSERT PRODUCT DATA, BUT THEY 
ARE NOT ALLOWED TO UPDATE OR DELETE IT. 


EXPORT DEPARTMENT PERSONNEL MAY SEARCH PRODUCT DATA, BUT THEY ARE NOT ALLOWED TO 


INSERT, UPDATE, OR DELETE IT. 


DATABASE 


MERCHANDISE OVERSEAS BUSINESS EXPORT 
DEPARTMENT DEPARTMENT DEPARTMENT 


SEARCH SEARCH SEARCH 
INSERT INSERT INSERT 
UPDATE UPDATE UPDATE 
DELETE DELETE DELETE 


WE WON'T JUST RESTRICT THE OH, YEAH... 
NUMBER OF USERS—WE WILL PUTTING THAT ASIDE, 
ALSO SET PERMISSIONS FOR WHAT I WANTED TO 


EACH USER WE ALLOW TO SAY 9... 
ACCESS THE DATABASE. 


THIS IS A GOOD 
OPPORTUNITY FOR YOU 
TO CONSIDER MARRIAGE 
WITH ME, AND... 


THIS WAY, PROBLEMS CAN BE 
AVOIDED AND THE DATABASE 
CAN STILL BE SHARED. 


142 CHAPTER 5 


SPEEDING ZAINGS UP WITH MDEXING 


AS THE DATABASE GROWS 
AND MORE AND MORE PEOPLE 
TENORED BEGIN USING IT, 


SOME OTHER YY FOR EXAMPLE, 
PROBLEMS MAY | THE GREATER THE 


THE SLOWER A 
SEARCH OPERATION 
MAY BECOME. 


INDEXING SEEMS TO BE A 
PROMISING SOLUTION. 


VOLUME OF DATA 
BECOMES, 


IS IT SAFE TO TRUST 
A DATABASE? 


AN INDEX LIKE ONE 
AT THE END OF A 


PRINCESS...I DON’T 
REALLY CARE. 
LET'S DISCUSS OUR 
MARRIAGE, INSTEAD. 
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SUPPOSE WE ARE GOING TO 
FIND THE MEANING OF THE TERM 
TRANSACTION BY CONSULTING 
THIS BOOK ON DATABASES. 


UNDER THE ENTRY FOR 
TRANSACTION, PAGES THAT 
DISCUSS TRANSACTIONS 
ARE LISTED. 


BY USING AN INDEX, 
WE CAN QUICKLY 
FIND THE PAGE 
WE’RE LOOKING 
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A BLIND SEARCH FOR 
THE TERM WOULD BE 
PAINSTAKING, 50 WE WOULD 
CHECK THE INDEX, INSTEAD. 


= 
3 


IT’S JUST THE 
SAME FOR A 
DATABASE INDEX. 
FOR EXAMPLE... 


IF YOU CREATE INDEXES 
FOR PRODUCT CODES, 


YOU CAN INSTANTLY 
LEARN WHERE PRODUCT 
DATA IS STORED FOR 
A PRODUCT ASSIGNED 
PRODUCT CODE 101. 


INDEXING HELPS SPEED UP 
THE SEARCH. 


_" WELL, IT’S NOT 
SO EASY FOR ME 
We TO FOLLOW.... 


pwn 


USING INDEXES, WE 
CAN REDUCE THE DISK 
ACCESS COUNT. 


IT TELLS YOU WHERE ON 
THE DISK THAT PRODUCT 
DATA IS LOCATED. 


IT IS VERY TIME CONSUMING 
TO BROWSE ALL ROWS 
WHEN SEARCHING FOR 
ve CERTAIN DATA. 


REPEAT THE 
EXPLANATION 
FROM THE 
START? 


HEY! WHO 
ARE YOU 


REDUCE THE DISK TALKING TO? 

ACCESS COUNT, AND 
OUR SEARCH WILL PRINCESS, 
BE MUCH FASTER! sie 


15 SOMEONE 
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JUST TALKING bb 
TO MYSELF! 


OOPS, RAMINESS 
CAN'T SEE HER. 


ON THE OTHER HAND, 
CREATING TOO MANY 
INDEXES MAY LEAD TO 
INEFFICIENCY. 


YOU SEE, IT'S LIKE THIS. 
SUPPOSE A BOOK HAD AN 
EXCESSIVELY LARGE NUMBER 
OF INDEXES. IT WOULD 
BE LIKE PUTTING THE CART 
IN FRONT OF THE HORSE, 
WOULDN'T IT? 


FURTHERMORE, WHEN 
UPDATING DATA, YOU MUST 
UPDATE YOUR INDEXES 
AS WELL, AND IT WOULD 
BE ALL THE MORE TIME 
CONSUMING. 
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NOW, EVERYBODY, 

IN A STANDARD DATABASE, 
I UNDERSTAND IT IS 
UP TO THE DATABASE 
ADMINISTRATOR TO ADD 
INDEXES. 


50 |S AN INDEX 
GOOD OR BAD? 


THAT'S HOW 
IT WORKS. 


N 
She 


I SEE. IT’S NOT SUPPOSED 
THE DATABASE IS . TO IMPRESS ME LIKE 


MORE CLEVER THAN \ MW THIS! IT HAS OTHER 
I THOUGHT. ‘ j \ PROBLEMS, TOO! 


WHAT IF THE SYSTEM ON {|p x Ne NO PROBLEM. 
WHICH THE DATABASE IS = | 
RUNNING GOES DOWN DUE 
TO POWER FAILURE? 


IT MEANS THE 
FUNCTION IS IN PLACE. RECOVERY? ZECOVER PROPERLY 
FROM TROUBLE, IF IT 
OCCURS. 
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DISASTER KRECOVERYS 


INSIDE A DATABASE, 
RECORDS CALLED LOGS 
ARE KEPT WHENEVER 
A DATA OPERATION IS 
PERFORMED, AREN'T THEY? 


THAT'S HOW CHANGES TO 
THE DATABASE’S CONTENTS 
ARE RECORDED. 


MOST IMPORTANT ARE RECORDS 
OF THE VALUES BEFORE AND 
AFTER A DATABASE UPDATE. 


HEY, HE IS 
ALSO GETTING 
INTERESTED IN 

DATABASES. 


YOU MEAN 
RAMINESS Io? 
ARE YOU SURE? 


148 CHAPTER 5 


WHEN A PROBLEM HAS THE RECOVERY METHOD 
OCCURRED IN THE SYSTEM, VARIES DEPENDING ON 


FIRST YOU RESTART THE WHETHER OR NOT THE 
SYSTEM. TRANSACTION HAS BEEN 
COMMITTED. 


THEN YOU UTILIZE LOGS 
TO RECOVER THE 
DATABASE. 


APPARENTLY, 

HE IS NOT 50 
KNOWLEDGEABLE... 

THAT'S A PITY. 


IF THE PROBLEM OCCURRED AFTER 
A TRANSACTION HAD ALREADY 
BEEN COMMITTED, THAT MEANS THE 
OPERATIONS HAVE BEEN FINALIZED 
FOR THAT TRANSACTION. 


50, YOU CAN RECOVER THE 
DATA BY REAPPLYING THE 
OPERATIONS TO THE DATABASE. | 


IN THIS RECOVERY, THE 
DATABASE REFERENCES 
THE VALUE AFTER THE 
UPDATE. OPERATION 


AFTER AN UPDATE 


THIS RECOVERY METHOD IS CALLED 
ROLLING FORWARD. 
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WHAT IF THE 
TRANSACTION HASN’T IN A ROLLBACK 


BEEN COMMITTED E 
YET WHEN THE BEFORE THE UPDATE IS 
? 
PROBLEM OCCURS? /, REFERENCED TO CANCEL 
m4 THE TRANSACTION. 


IN OTHER WORDS, IT 
RESTORES THE STATE 
OF THE DATABASE INITIAL STATE 
BEFORE THE 
TRANSACTION WAS 
STARTED. 
DON’T WORRY! 
IN THAT CASE, A ROLLBACK 
TAKES PLACE. 


THE SYSTEM RECOVERS 

THE DATA WHILE MAKING I AM NOT FAMILIAR WITH 
SURE IT IS FREE FROM Aly TERMS LIKE COMMIT AND 
INCONSISTENCIES. k i TRANSACTION. 


STILL, IT SEEMS YOUR YOU SEE, A DATABASE 
DATABASE SECURITY IS ROBUST! EVEN 


MEASURES ARE ALL WHEN DISASTER 
\ STRIKES! 


NOW DO YOU 
UNDERSTAND? 
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WELL, GIVEN ALL THAT, 
I WILL LET YOU GET 
AWAY WITH IT THIS 
TIME. 


/ gf P wf ; Cae 
i 
A ee 


Zo 


I AM SERIOUS 
ABOUT OUR 
MARRIAGE, OKAY? 


I LOVE 
SOMEONE ELSE! 


I CANNOT ACCEPT 
YOUR PROPOSAL. 


PASSIONATELY 
STARING 


I'LL BE WITH CAIN FOREVER, 
AND WITH THE POWER OF 
OUR DATABASE, 


WE WILL SEE TO IT THAT 
THE KINGDOM OF KOD 
WILL THRIVE! 


Va 
Kyou PREFER 
WHAT ON EARTH? SOMEBODY 


' t AS HUMBLE ve 
acta ne vO AS CAIN? APOLOGIZING, 


THEY MAKE 
A GREAT 
COUPLE. 


os 
Sal WHY, OH, WHY? @ 
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PROPERTIES OF ZKANSACTIONS 


Cain's research showed that users of a database can search for, insert, update, and delete 
data. A set of successful operations performed by a single user is called a transaction. 


= 
DATABASE 


TRANSACTION 


V/ 
(XD 


When users share a database, it is important to ensure that multiple transactions 
can be processed without causing conflicting data. It is also important to protect data from 
inconsistencies in case a failure occurs while a transaction is being processed. To that end, 
the following table lists the properties required for a transaction, which memorably spell the 
word ACID. 


PROPERTIES REQUIRED FOR A TRANSACTION 


Property Stands for Description 


A Atomicity A transaction must either end with a commit or rollback 
operation. 
c Consistency Processing a transaction never results in loss of consistency 


of the database. 


Isolation Even when transactions are processed concurrently, the 
results must be the same as for sequential processing. 


D Durability The contents of a completed transaction should not be 
affected by failure. 


Let's examine each of these properties in depth. 


ATOMICITY 


The first property required for a transaction, atomicity, means that a transaction must end 
with either a commit or rollback in order to keep a database free of inconsistencies. In short, 
either all actions of a transaction are completed or all actions are canceled. A commit final- 
izes the operation in the transaction. A rollback cancels the operation in the transaction. 
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[ae oe ae 
DATABASE 


Soeire S| 
DATABASE 


[comm 'p ROLLBACK 


In some cases, a commit or rollback is performed automatically. You can also specify 
which one should be carried out. For example, you can specify a rollback if an error occurs. 
You can use the SQL statements COMMIT and ROLLBACK to perform these operations. 


COMMIT ; Use this statement to 
TT _] COMMit a transaction. 


ROLLBACK; Use this statement to 


roll back a transaction. 


QUESTIONS 
Answer these questions to see how well you understand atomicity. The answers are on 
page 167. 


Q1 
Write an SQL statement that can be used to finalize a transaction. 


a2 
Write an SQL statement that can be used to cancel a transaction. 


CONSISTENCY 


A transaction must not create errors. If the database was consistent before a transaction is 
processed, then the database must also be consistent after that transaction occurs. 

Cain gave the example of Andy and Becky each trying to add 10 apples to an origi- 
nal total of 30 apples. Rather than yielding the correct amount of 50 apples, the database 
shows a total of 40 apples. This type of error is called a /ost update. 


BSS 
30 APPLES 


30 APPLES 


OY 


HO APPLES 


30 APPLES 
40 APPLES — /\ 


HO APPLES 
oy 


40 APPLES 


When transactions are processed concurrently, more than one transaction may access 
the same table or row at the same time, and conflicting data may occur. 

Tables and rows subject to operations in a transaction are referred to as resources. In 
a database, transactions should be able to access the same resource concurrently without 
creating inconsistencies. 


So. 


ISOLATION 


When two or more concurrent transactions yield the same result as if they were performed 
at separate times, that order of processing is referred to as serializable. The isolation prop- 
erty requires the schedule to be serializable and protects against errors. 

In order to make the order of processing serializable, you need to have control over 
transactions that are attempted at the same time. The most commonly used method for 
this purpose is the lock-based control. A shared lock is used when reading data, while an 
exclusive lock is used when writing data. 
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© SHARED LOCK 


When a shared lock is in use, another user can apply a shared lock to other transac- 
tions, but not an exclusive lock. When an exclusive lock is applied, another user cannot apply 
a shared lock or an exclusive lock to other transactions. The following summarizes the rela- 
tionship between a shared lock and an exclusive lock. 


CO-EXISTENCE RELATIONSHIP BETWEEN LOCK TYPES 


Fexcusve ck [wo [wo ‘| 


QUESTIONS 


Do you understand locks? Answer these questions and check your answers on page 167. 


Q3 
When Andy has applied a shared lock, can Becky apply a shared lock? 


Q4 
When Andy has applied an exclusive lock, can Becky apply a shared lock? 


Qs 
When Andy has applied a shared lock, can Becky apply an exclusive lock? 


Q6 


When Andy has applied an exclusive lock, can Becky apply an exclusive lock? 


TWO-PHASE LOCKING 


In order to make sure a schedule is serializable, we need to obey specific rules for setting 
and releasing locks. One of these rules is two-phase locking—for each transaction, two 
phases should be used: one for setting locks and the other for releasing them. 

For example, suppose there are resources A and B, both subject to locking. Transaction 
@ observes the rule of two-phase locking, while transaction ® does not. Serialization can 
only be achieved when each transaction complies with the rule of two-phase locking. 


LOCK B v READ A 

READ A RITE A 

READ B UNLOCK A Locks have been 
RITE A LOCK B released here before 
RITE B READ B writes are applied. 
UNLOCK A | RITE B 

UNLOCK B releasing locks UNLOCK B 


LOCKING GRANULARITY 


There are a number of resources that can be locked. For example, you can lock data in 
units of tables or units of rows. The extent to which resources are locked is referred to as 
granularity. Coarse granularity occurs when many resources are locked at once, and fine 
granularity occurs when few resources are locked. 


Locking in units of 
rows involves a fine 
granularity for locking. 


Locking in units of 


tables involves a coarse 
granularity for locking. 


When granularity is coarse (or high), the number of locks needed per transaction 
is reduced, making it easier to manage granularity. In turn, this reduces the amount of 
processing required by the CPU on which the database is operating. On the other hand, 
as more resources are locked, it tends to take longer to wait for locks used by other trans- 
actions to be released. Thus, the number of transactions you can carry out tends to drop 
when granularity is high. 

In contrast, when granularity is fine (or low), a greater number of locks are used in one 
transaction, resulting in more operations for managing locks. This results in greater process- 
ing required by the CPU. However, since fewer resources are locked, you will spend less time 
waiting for other transactions to release locks. Thus, the number of transactions you can 
carry out tends to increase. 


QUESTIONS 
Answer these questions, and check the correct answers on page 168. 
Q7 


The target resource for locking has been changed from a table to a row. What will 
happen to the number of transactions you can carry out concurrently? 


Qs 
The target resource for locking has been changed from a row to a table. What will 
happen to the number of transactions you can carry out concurrently? 


LET'S OPERATE A DATABASE! 157 


OTHER CONCURRENCY CONTROLS 


You can use locking to effectively carry out two or more transactions at the same time. 
However, using locking comes with the burden of lock management, since deadlocks—places 
where user actions conflict—can occur. Simpler methods for concurrency control can be 
used when you have a small number of transactions or a high number of read operations. 
In such cases, the following methods may be used: 


Timestamp Control 
A label containing the time of access, referred to as a timestamp, is assigned to data 
accessed during a transaction. If another transaction with a later timestamp has already 
updated the data, the operation will be not permitted. When a read or write operation 
is not permitted, the transaction is rolled back. 


Optimistic Control 
This method allows a read operation. When a write operation is attempted, the data 
is checked to see if any other transactions have occurred. If another transaction has 
already updated the data, the transaction is rolled back. 


LEVELS OF ISOLATION 


In a real-world database, you can set the level of transactions that can be processed con- 
currently. This is referred to as the isolation level. 

In SQL, the SET TRANSACTION statement can be used to specify the isolation levels of 
the following transactions: 


* — READ UNCOMMITTED 
* — READ COMMITTED 

* — REPEATABLE READ 

* — SERIALIZABLE 


SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED; 


Depending on the isolation level setting, any of the following actions may occur. 


Dirty read Non-repeatable read Phantom read 
READ UNCOMMITTED Possible Possible Possible 
READ COMMITTED Will not occur Possible Possible 
REPEATABLE READ Will not occur Will not occur Possible 
SERIALIZABLE Will not occur Will not occur Will not occur 


* — Adirty read occurs when transaction 2 reads a row before transaction 1 is committed. 

* — Anon-repeatable read occurs when a transaction reads the same data twice and gets 
a different value. 

* — A phantom read occurs when a transaction searches for rows matching a certain 
condition but finds the wrong rows due to another transaction’s changes. 
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DURABILITY 


A database manages important data, so ensuring security and durability in the case of fail- 
ure is critical. Security is also important for preventing unauthorized users from writing data 
and causing inconsistencies. 

In a database, you can set permissions for who can access the database or tables in it. 
Cain avoids dangers to the Kingdom's database by enhancing the database's security. 

In a relational database, the GRANT statement is used to grant read and write per- 
missions to users. You can use GRANT statements to grant permission for other users to 
process tables you have created. Setting permissions is an important task for database 
operation. 


GRANT SELECT, UPDATE ON product TO Overseas Business Department; This statement grants 
permission to process data. 


You can assign the following privileges (permissions) with SQL statements. 


DATABASE PRIVILEGES 


Statement Result 

SELECT Allows user to search for rows in a table. 
INSERT Allows user to insert rows in a table. 
UPDATE Allows user to update rows in a table. 
DELETE Allows user to delete rows in a table. 
ALL Gives user all privileges. 


Granting a privilege with WITH GRANT OPTION enables the user to grant privileges 
to other users. With the statement shown below, the Overseas Business Department can 
allow other users to search and update the database. 


GRANT SELECT, UPDATE ON product TO Overseas Business Department The granted user can grant 
WITH GRANT OPTION; privileges to other users. 


You can also take away a user’s privileges. To do this, use the REVOKE statement. 


REVOKE SELECT, UPDATE ON product FROM This statement revokes 
Overseas Business Department; the user’s privileges. 


Some database products can group a number of privileges and grant them to multiple 
users at once. Grouping makes privilege management easier. 
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[ara ae 
Grants privileges to 
DATABASE multiple users using groups. 
DEPT. 


Using views, as described on page 117, enables even more controlled management for 
enhanced security. First, extract part of a base table to create a view. Setting a privilege for 
this view means the privilege is also set on the selected portion of data in the view. 


MERCHANDISE ONERSERS 
DEPT. BUSINESS 
° DEPT. 


kw feo} 


View Base table 


FER 


Users can process the Users cannot process the 


data in this view. data in the rest of the table. 


QUESTIONS 


Try these questions on durability. The answers are on page 168. 


a9 
Write an SQL statement that allows the Export Department to search for data in the 
Product Table. 


Qio 
Create an SQL statement to revoke the Overseas Business Department's privilege to 
delete data from the Product Table. 


qQi1 
Privileges were set as follows on a Product Table created by the administrator. Enter 
a YES or NO in each cell of the table below to indicate the presence or absence of the 
privilege for each department, respectively. 


GRANT ALL product TO Overseas Business Department; 
GRANT INSERT, DELETE ON product TO Merchandise Department; 
GRANT UPDATE, DELETE ON product TO Export_Department; 


Search Insert Update Delete 


Overseas Business Dept. 


Merchandise Dept. 


Export Dept. 


WHEN DISASTER STRIKES 


A database needs to have a mechanism that can protect data in the system in the event of a 
failure. To ensure durability of transactions, it is mandatory that no failure can create incor- 
rect or faulty data. To protect itself from failure, a database performs various operations, 
which include creating backup copies and transaction logs. 


TYPES OF FAILURES 


Database failure can occur under various circumstances. Possible types of failure include the 
following: 


* Transaction failure 
* — System failure 
7 Media failure 


Transaction failure occurs when a transaction cannot be completed due to an error in 
the transaction itself. The transaction is rolled back when this failure occurs. 

System failure occurs when the system goes down due to a power failure or other such 
disruption. In the case of a system failure, disaster recovery takes place after you reboot the 
system. Generally, transactions that have not yet been committed at the time of failure are 
rolled back, and those that have already been committed when a failure occurs are rolled 
forward. 

Media failure occurs when the hard disk that contains the database is damaged. In the 
case of a media failure, disaster recovery is carried out using backup files. Transactions com- 
mitted after the backup files were created are rolled forward. 


CHECKPOINTS 


In order to improve the efficiency of a write operation in a database, a buffer (a segment of 
memory used to temporarily hold data) is often used to write data in the short term. The 
contents of the buffer and the database are synchronized, and then a checkpoint is written. 
When the database writes a checkpoint, it doesn't have to perform any failure recovery for 
transactions that were committed before the checkpoint. Transactions that weren't commit- 
ted before the checkpoint must be recovered. 

Now, suppose the transactions shown below are being performed at the time a sys- 
tem failure occurs. Which transactions should be rolled back? Which ones should be rolled 
forward? 


Checkpoint Failure occurrence Time 


Commit 
Start Commit 
T3 SS 
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QUESTIONS 


Try these questions based on the table on the previous page. The answers are on page 168. 


Q12 
How should T1 be processed? 


Q13 
How should T2 be processed? 


Qi4 


How should T3 be processed? 


In case of database failure, the recovery mechanisms described above will protect the 
database against inconsistency. That is why you can be reassured of database integrity when 
you use it. 


A database manages massive amounts of data, so searching for specific data can be very 
time consuming. But you can use indexes to speed up searches! 


Tere District 


300G South Sea 
02 


It is very time 
consuming to 


search for each 
item row by row. 


An index is a tool that allows you to speedily access the location of the target data. 
When looking for some data in a large database, searching with indexes promises fast 
results. 


The target data 
location can be 


accessed quickly 
by using its index. 


02 


Indexing methods include B-tree and hash methods. A B-tree index is composed of 
parent nodes and child nodes, which can have further child nodes. The nodes are arranged 
in sorted order. Each parent contains information about the minimum and maximum values 
contained by all of its children. This allows the database to navigate quickly to the desired 
location, skipping entire sections of the tree that cannot possibly contain the desired value. 


200 In a B-tree index, the 
target location can be 
accessed quickly. 


The hash index method finds the location of target data by applying a hash function to 
the key value of the data. The hash acts as a unique fingerprint for a value. The hash index 
method can perform specific full-match searches, such as a search for product code 101. 
However, it is not designed to search effectively for comparative conditions like product 
codes no less than 101 or for fuzzy references like products with names ending inn. 


In a hash index, the 
target location can be 
reached quickly. 


a} 


Hash 
function 


In some cases, using an index may not speed up the search—using an index doesn't 
save time unless you are looking for only a small portion of the data. Additionally, there are 
cases where indexes are recreated every time data is updated, resulting in slower processing 
of an update operation. 
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QUESTIONS 


Try these questions on indexing. The answers are on page 168. 


qQi5 
Which index would be more powerful in a search with an equal sign, a B-tree or hash 
index? 


Q16 
Which index would be more powerful in a search with an inequality sign, a B-tree or 
hash index? 


OPTIMIZING A QUERY 
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When you query a database, the database analyzes the SQL query and considers whether 
to use an index so it can process the query more quickly. Let’s examine the procedure for 
processing a query. 

The database can decide on an optimal order to process a query. Most queries can be 
processed in several orders with the same results, but with possibly different speeds. For 
example, suppose there is a query to extract dates of sale and product names for products 
with a unit price greater than 200G. This query can be seen as consisting of the following 
steps. 


SELECT date, product_name 

FROM product, sales 

WHERE unit_price>=200 

AND product.product_code = sales.product_code; 


1. Join the Product Table and the Sales Table. 
Z. Select products whose unit price is greater than 200G. 
3. Extract columns of dates and product names. 


For example, the figure on the left below shows the query processed in order from 1 to 
3. The figure on the right shows the query processed in order from 3 to 1. Either way, the 
queries are equivalent. 


SALES PRODUCT PRODUCT 
TABLE TABLE TABLE 
SALES 
JOIN TABLE 
PROJECTION 
SELECTION 
PROJECTION SELECTION 
PROJECTION JOIN 


However, when processed from 1 to 3, the same query would generally require a 
longer processing time, because when the first join is performed, an intermediate table 
with many rows may be created. On the other hand, the procedure from 3 to 1 requires 
a shorter processing time, since selection and projection happen first, trimming unwanted 
data as soon as possible. Thus, the same query may require a different processing time, 
depending on the order in which projection, selection, and join are performed. 

Generally, the database should use the following rules to find the best querying order: 


* Execute selection first to reduce the number of rows. 
* Execute projection first to reduce the number of columns irrelevant to the result. 
* — Execute join later. 


There are different techniques for executing projection, selection, and join, respectively. 
For selection, you can use either a full-match search or an index-based search. For join, the 
following methods are available. 


NESTED LOOP 


The nested loop method compares one row in a table to several rows in another table (see 
the figure below). For example, one of the values in a row in Table T1 is used to find match- 
ing rows in Table T2. If the values are the same, then a joined row is created. 


TABLE TZ 
TABLE T1 


All rows are 


compared for 
each row. 
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SORT MERGE 


The sort merge method sorts and then merges rows in multiple tables (see the figure 
below). First, all or part of Tables T1 and T2 are sorted. Then they are compared starting 
with the top row, and a joined row is created whenever the same value is found. Since they 
have already been sorted, processing only needs to be done in one direction, so it will take 
less time. You should be aware, however, of the time needed for the initial sorting. 


TABLE T1 TABLE TZ 


First sort, 
then compare. 


HASH 


A hash divides one of the tables using a hash function and then merges it with a row in 
another table that has the same hash value. This method effectively selects the row to join. 


TABLE TZ 


Hash Hash 
function function 


SUMMARY 


ANSWERS 


OPTIMIZER 


When a query is processed, these different techniques are examined for optimal perfor- 
mance. In a database, the function in charge of optimization of queries is referred to as the 
optimizer. There are two common types. 


RULE-BASED PROCESSING 


Certain rules are established before any operations are performed. For example, some 
operations can be combined or reordered in much the same way an algebraic equation can 
be manipulated and still mean the same thing. The optimizer tries to find the most efficient 
way to process the query that gives the same results. 


COST-BASED PROCESSING 


This method tries to estimate the cost of processing the query, based on statistics that the 
database maintains. Cost-based processing is sometimes more flexible than rule-based 
processing, but it requires periodical updates of the database's statistics. Managing and 
analyzing these statistics requires a lot of time. 


* — You can set user privileges for a database. 

* Locking ensures consistency when a database has multiple users. 
*  |ndexing enables fast searches. 

* — Adatabase has disaster recovery functions. 


Qi 


COMMIT; 


Q2 


ROLLBACK; 


Q3 Yes 
Q4 No 
Q5 No 
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Q6 No 
Q7_ Increases 
Q8 Decreases 


Q9 


GRANT SELECT ON product TO Export Department; 


Qio 
REVOKE DELETE ON product FROM Overseas Business Department; 
qQi1 
Search Insert Update Delete 
Overseas Business Dept. YES YES YES YES 
Merchandise Dept. NO YES NO YES 
Export Dept. NO NO YES YES 
Qi2 
A rollback is performed since it is not committed at the time of the failure occurrence. 
Qi3 
A roll forward is performed since it has been commited at the time of the failure 
occurrence. 
Q14 
No recovery operation is needed since it has been committed at the time of checkpoint. 
qi5 
Hash 
Q16 
B-tree 
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HOW DELICIOUS! THIS 
FRUIT IS FROM THE 
KINGDOM OF KOD! 


YES? WHAT'S THE 

MATTER? DO YOU 

WANT A BANANA, 
TOO, RURUNA? 


FATHER, puts FORGIVE 
MUNCHING ME! NO 


ON FRUIT IS OTHER FRUIT 
ALL YOU HAVE & COMPARES! 
DONE SINCE - 
YOU HAVE 
RETURNED. 


BUT I ADMIT, RURUNA SALLY 
KEPT A TIGHT REIN : B eeelig 
WHILE I WAS AWAY. e A CONVENIENT 


LOOK AT HOW 

PROSPEROUS 

THE KINGDOM 
OF KOD Id! 


BUT YOU MUST Have 
COME FOR SOME | KS, : T...TICO... HAVE 
OTHER BUSINESS, YOU SEEN 


WHAT ARE YOU 
SHE WAS A BIG HELP 
YES. OH...TICO IS A TALKING ABOUT? TO CAIN AND ME WHILE 


GIRL ABOUT THIS I'VE NEVER SEEN 
BIG, AND SHE FLIES HER BEFORE, YOU WERE AWAY. 
IN THE AIR... 


SHE CAME OUT OF 
THE BOOK YOU 
GAVE ME, FATHER. 


I THOUGHT FATHER HAVE YOU —NO,, I 
WOULD KNOW HER SEEN HER? HAVEN'T. 
BECAUSE SHE CAME i 
FROM THE BOOK HE 

GAVE ME. 


AS I THOUGHT, 
TICO IS INVISIBLE 
EXCEPT TO CAIN 

AND ME. 


TICO HAS 
DISAPPEARED! 


WHERE ON EARTH 
HAS SHE GONE? 


AND SHE DOESN'T 
APPEAR TO BE IN THE 
BOOK, EITHER. 


I'LL LOOK AROUND 
THE CASTLE 
GROUNDS AGAIN. 


I’M SORRY! 


OH, EXCUSE ME, 
PRINCESS. 


YOUR HIGHNESS, 
THOSE TWO ARE 
REALLY... 


GETTING ALONG, 
AREN'T THEY? 
SHE’S GONE! 


sel 


LIK 
23H XK 


I'D LIKE TO 
BID HER... 


TICO, WHY HAVE YOU 
DISAPPEARED ALL OF 
A SUDDEN? 


AT LEAST A 
FAREWELL. 
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RURUNA, DON’T 
IT’S NOT NICE BE MAD! I WAS WORRIED 
TO GIGGLE : ABOUT YOU! 
LIKE THAT! 


WHERE HAVE 
YOU BEEN? 


I WAS FLYING oo THANKS TO 


AROUND TO SEE HOW THE DATABASE, 
EXTENSIVELY THE THINGS ARE 
DATABASE |S BEING ox fe NOW FAR MORE 
USED IN THE KINGDOM JagN' EFFICIENT. _/ 


OF KOD. 


OH, I SEE. 7K 


OVERSEAS, THERE ARE 
COUNTRIES WHERE 
DATABASES ARE USED 
FOR VERY DIFFERENT 
PURPOSES. 
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DAacaBases In YSéE 


FOR EXAMPLE, IN SOME 

COUNTRIES, DATABASES 

ARE USED AT BANKS TO 
MANAGE ACCOUNTS! 


BANKS WITH 
DATABASES! 


THAT SOUNDS SO 
CONVENIENT! 


PAYMENTS 
CAN BE MADE 
THROUGH A 
DATABASE! 


ALL ABOARD! 


WITH A DATABASE, 
BOOKING WOULD BE 
POSSIBLE FROM ANY 

STATION. 


SUPPOSE AN 
ACCOUNT CAN BE 
SHARED BY ALOT 

OF PEOPLE.... 


YOU COULD 
WITHDRAW FROM 
YOUR OWN 
ACCOUNT AS WELL 
AS TRANSFER 
MONEY INTO 
SOMEBODY 
ELSE'S ACCOUNT. F'*) 


SOMETIMES TRAIN SEAT 
RESERVATION SYSTEMS 
USE DATABASES. 


REMEMBER THE LESSON 
ON LOCK-BASED 
OPERATIONS? 


DATABASES ARE EVERYWHERE! 


RESERVATIONS 


THAT'S THE 
FUNCTION NEEDED 
TO ENABLE A 
LOT OF PEOPLE 
THAT'S TRANSACTION TO MAKE 
CONTROL USING RESERVATIONS 
LOCKS, RIGHT? 3 


FROM DIFFERENT 
STATIONS AT 
THE SAME TIME 
WITHOUT DOUBLE 
BOOKING. 


= THAT'S RIGHT! BANK 
AND SECURITY AND : @ DATABASES DEFINITELY NEED 
COUNTERMEASURES THOSE FUNCTIONS 
AGAINST FAILURE r , 


ARE ALSO IN PLACE. 


MEASURES 1 \} IT WOULD 
AGAINST WX BE AWFUL IF 
FAILURE S HL SOMEONE COULD 

: WITHDRAW MY 
MONEY AT WILL. 


I'D BE FLAT 
BROKE IF MY 
DATABASES ARE ACCOUNT WERE 
ACTIVELY HELPING US EMPTIED. rl eee 
EVERYWHERE. ; 


‘ 
cal; se 
NEN 


Li 
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DacaBbases anD ThE WEB 


A DATABASE 
FOR EXAMPLE? SYSTEM LINKED 
: TO THE WéeB! 


WOW, I 
WANT THIS 


OVERSEAS, PEOPLE CAN 
BUY VARIOUS GOODS 
FROM WEB PAGES. 


50...YOU DON’T HAVE 
THAT SOUNDS SO fe FOR EXAMPLE, TO MAKE A LIST OF 
CONVENIENT! SXZ¥ YOU CAN BUY ANY TITLES AND GO TO A 


BOOK YOU WANT... BOOKSHOP! 


tam oN 
2" ABSOLUTELY 
THAT SYSTEM! 


BY BROWSING A 
WEB PAGE. 
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WN yd linn \A\\ 7 ; 


WHEN YOU 
LOOK FOR A 
CERTAIN BOOK 
YOU HAVE IN 


CATEGORIES || 
KEYWORD 


ENTER A KEYWORD IN 
A WEB BROWSER. 


WHAT CATEGORY 
OF BOOKS ARE YOU 
LOOKING FOR? 
THEN TYPE 
FRUIT |N THIS 
KEYWORD 
FIELD. 


WELL, LET ME SEE...THAT 
WOULD BE “FRUIT,” I GUESS. 


5 Rook AN SQL STATEMENT |S 
THIS KEYWORD IS SENT OUT 1 Vee MADE ON THE SERVER, 
AS AN HTTP REQUEST. ; I SUPPOSE. 


CATEGORIES |¥| 
KEYWORD 


A COMPUTER THAT 
RECEIVES A REQUEST 
AND PROCESSES IT IS A 
SERVER. 
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DATABASE SERVER 


SELECT product_name 
FROM product 

WHERE product_name 
LIKE '%fruit%'; 


SEARCH 
CONDITION 


FRUIT 


OH, BOY! 


THEN, THIS SQL STATEMENT 
IS SENT TO THE DATABASE 
FOR QUERYING. 


IN TURN, THE DATABASE RETURNS 
PRODUCT DATA AS A RESULT. 


Bi 
ay 


DATABASE, 
SERVER 
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THE SERVER CREATES ne | peas eens. 


A WEB PAGE CARRYING 
THIS SEARCH RESULT AND 
SENDS IT TO THE USER. 


DATABASE SERVER 


RETRIEVING 


ROUTER P 


ROUTER P 


180 CHAPTER 6 


WHEN YOU PURCHASE 
A PRODUCT, A SIMILAR 


THIS IS HOW WE 
CAN SEE A LIST OF PROCESS TAKES 


BOOKS ABOUT FRUIT 
ON A WEB PAGE. 


wow, 1D \ 
LOVE TO 
BUY IT! 


IN THAT CASE, AN SQL 
STATEMENT |S ISSUED ks 50...5QL AGAIN. 
TO REDUCE THE NUMBER j 
OF ITEMS IN STOCK 


WHAT'S 
THAT? 


FROM THE INVENTORY 
TABLE, AND THEN THE \\\. | RURUNA, WILL \ 
ITEM YOU ORDERED " YOU LOOK AT 
IS ADDED TO THE ke 
SHIPPING TABLE. 


WHAT COULD |: | | WHAT IS 5 wonper 


: THIS!? WHEN 
THAT BE? FATHER 
PUBLISHED 


T | IT2 
@ + aii 


FRUIT LOVE) @ pe -OMMENDED: 


FRUIT LOVE 
BY THE KING OF KOD 


By THE }° 
KING OF KOD 


SOMETIMES YOU DO 
FIND SOMETHING 
WEIRD, HUH? 
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I IMAGINE A LOT OF 

CUSTOMERS ACCESS 

A WEB BOOKSHOP AT 
THE SAME TIME. 


EVEN IF LOCKS AND 
SECURITY FUNCTIONS 
GIVE THE DATABASE FULL 
PROTECTION, 


IN THAT CAGE, 
THE BURDEN OF 
PROCESSING IS 
SHARED AMONG 

A NUMBER OF 

SERVERS. 


VY YOU MEAN MORE 
THAN ONE SERVER 
IS INVOLVED? 


A WEB SERVER |5 A 
SERVER IN CHARGE OF 
CREATING A WEB PAGE, 

ISN’T IT? 
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IT MUST BE A LOT OF 
PROCESSING. 


YES, THE LOAD |S DISTRIBUTED 
AMONG DIFFERENT SERVERS, LIKE 
A WEB SERVER AND AN APPLICATION 
SERVER. 


YEP! AND AN APPLICATION 
SERVER |S IN CHARGE OF 
COMPOSING SQL STATEMENTS, 
AMONG OTHER THINGS. 


DISTRIBUTED DaATAaBasEes 


Py 


CAN THE LOAD BE 
SHARED AMONG \ 
DATABASE SERVERS? 


YES, AND WHEN THAT 
HAPPENS, IT IS REFERRED 
TO AS A DISTRIBUTED 
DATABASE. 


YOU SHOULD NOTE, 
HOWEVER, THAT THESE 
SERVERS CAN ACT ASA 

SINGLE DATABASE. 


IT IS CONVENIENT THAT 
A NUMBER OF SERVERS 
CAN ACT AS A SINGLE 
DATABASE. 


IT SOUNDS LIKE 
A DATABASE 
MANAGED BY 
A NUMBER OF 

SERVERS. 


THAT MAKES IT POSSIBLE 
FOR EACH SERVER TO 
MANAGE ACCORDING TO 
ITS CAPACITY. 
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MANY SERVERS 
PROVIDE EXTRA 
PROTECTION 
AGAINST FAILURE, 
TOO! 


THAT MEANS THE ENTIRE 
DATABASE SYSTEM 
WON'T GO DOWN, EVEN 
IF FAILURE OCCURS ON 
SOME SERVERS IN THE 
SYSTEM. 


BUT KEEP THIS IN MIND: 
IT TAKES SOME CARE TO 
HANDLE YOUR DATABASE IN 

THIS WAY. 


ALSO, FOR INSTANCE, ALL 
SERVERS MUST BE UPDATED 
PROPERLY IN CASE ANY 
PROBLEM OCCURS ON THE 
NETWORK. 


WHEN A TRANSACTION IS 
COMMITTED, YOU MUST 
ENSURE CONSISTENCY 

ACROSS YOUR DISTRIBUTED 
DATABASE. 
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STORED PROCEDURES AnD TRIGGERS 


RIGHT! THAT'S 
WHERE STORED 
PROCEDURES ARE 

USEFUL; 


A NETWORK IS A MUST 
IN ANY ENVIRONMENT 
WHERE A SET OF 
SERVERS IS USED. 


THEY ARE SOMETIMES 
CREATED TO HELP REDUCE 
THE BURDEN ON THE 
NETWORK. 


DOESN'T STORE MEAN PUT 
INTO MEMORY, IN OTHER 
WORDS? 


RIGHT! 


IN ORDER TO REDUCE THE 
BURDEN ON THE NETWORK, 
FREQUENTLY USED OPERATIONS 
CAN BE STORED IN DATABASES. 


FREQUENTLY USED 
OPERATIONS, YOU WELL, SINCE WE 
SAY.. WHAT KIND OF WERE TALKING ABOUT 
OPERATIONS ARE THEY, OPERATIONS FOR BUYING 
I WONDER? A BOOK, SUBTRACTING 
FROM THE IN-STOCK 
COUNT IN THE INVENTORY 
TABLE AND ADDING DATA 
TO THE SHIPPING TABLE— 


AREN'T THOSE 
TYPICAL 
OPERATIONS? 
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WE CAN STORE OPERATIONS 
THAT ARE LIKELY TO BE 
USED FREQUENTLY AS 
PROCEDURES 


YEAH, 
INDEED. 


IN THE DATABASE 
BEFOREHAND! 


(h 


cc. As 


OUR WOR 
IF WE PREPARE A REDUCED, FOO. 


STORED PROCEDURE, 
WE WON'T HAVE 
TO ISSUE AN SQL 

STATEMENT 


EACH TIME WE 
WANT TO REDUCE 
THE INVENTORY 
AND PROCESS 


A SHIPPING we 
OPERATION. : THAT WAY, THE 


OPERATIONAL LOAD 
ON THE NETWORK IS 
REDUCED. 


BESIDES THAT, YOU KNOW, 
THERE ARE STORED 
PROCEDURES THAT ARE 
AUTOMATICALLY STARTED. 


AUTOMATICALLY? 


186 CHAPTER 6 


WHEN DATA IS UPDATED, TRIGGER... 
FOR EXAMPLE, A IT’S CALLED A 
STORED PROCEDURE TRIGGER. 
CAN AUTOMATICALLY 
START. 


IT WOULD BE 
BECAUSE IT DOES = CONVENIENT, 
WHAT A TRIGGER ON INDEED, IF PLACING 
A GUN DOES! oy AN ORDER AND 
UPDATING THE 
DATABASE 


AUTOMATICALLY 
LAUNCHED AN 
OPERATION TO 
REDUCE THE 
INVENTORY AND 
ARRANGE FOR 
SHIPPING. 


JUST BUYING ONE 
BOOK CREATES A LOT 
OF WORK BEHIND THE 
SCENES, DOESN'T IT? 


PULL THE TRIGGER AND A 
BULLET IS SHOT. UPDATE DATA 
AND A STORED PROCEDURE IS 

ACTIVATED. 
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EXACTLY. 


ALTHOUGH IN MOST 


CASES, THE DATABASE 


MAY NOT BE VISIBLE 


WHEN YOU 
PURCHASE A BOOK 
ON THE WEB. 


YES, I AGREE, 
PRINCESS. 


TICO HAS HELPED 
US TO LEARN HOW 
TO USE A DATABASE, 


AND WE CAN MOVE 
FORWARD FROM 
HERE. 


SOUNDS GOOD! 
WATCH ME. BY USING 
DATABASES, 


I WILL BUILD 
A WONDERFUL 
COUNTRY WHERE 
EVERYONE 
CAN ENJOY A 
CONVENIENT WAY 
OF LIFE. 


FOR OUR PART, WE 
NEED TO LEARN 
MORE ABOUT THIS 
STEP BY STEP. 


y 
— 

(i, DON’T YOU 
THINK SO, 


RIGHT! 


DON’T FORGET THAT 
DATABASES ARE THE MAIN 
WAY TO CONVENIENTLY 
ORGANIZE YOUR DATA. 


YOU HAVE 
MADE REAL THAT'S 
Le planes PROGRESS... FOR WHAT ARE YOU 
UNDERSTANDING THE _ TALKING ABOUT? 
MECHANICS OF A 


DATABASE SYSTEM. YOU WILL STAY 


WITH US, WON’T 


YOU, TICO? 
BUT I'M SURE YOU 


WILL BE ALL RIGHT 
ON YOUR OWN. 


SORRY, 


SSK 
S 
Ss 


I HAVE MORE 


MY WORK HERE PEOPLE TO 
IS DONE. 


WS 


THERE ARE MANY PEOPLE 
THAT WISH TO LEARN ABOUT 
DATABASES, YOU KNOW! 


THEN ARE YOU GOING 
TO VISIT SOMEONE ELSE 
WHO HAS OPENED A 
BOOK ON DATABASES? 
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fz 


<7 


= 


IT’S BEEN A SHORT 
BUT HAPPY TIME WITH 
YOU Two! 
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eS | 
‘ae, 


——S Sy 
Vii = 


SES 
iN 


Sa=zy:«CWEE: HAVE THE TASK 
OF IMPLEMENTING 
IT IS PAINFUL 
FOR ME TO SEE THE KNOWLEDGE 
YOU LOOKING SO TICO HAS GIVEN US 


SAD, PRINCES’ 


NN | 


INTO A REAL 
SYSTEM. 


Days Have GONE BY... 


DO YOU WANT SURE! 


I AM MAKING 
THINGS EASY FOR 
EVERYBODY TO 


UNDERSTAND. i : 
Se = Seen, 


HERE! THIS IS THE 
FRONT COVER. 


| 
| 


Ih ‘ 
wc 
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IS EVERYTHING ALL 
RIGHT WITH YOUR 
BOOK ON DATABASES, 
PRINCESS? 


IT’S A GOOD 
IDEA TO DO 
IT INA COMIC 
BOOK STYLE. 


AND CAIN’S 
DRAWINGS ARE 
EXCELLENT. 


; [| SPEAKING OF CAIN, 
THAT'S REALLY Rite. | THE KING IS WAITING 


NICE. bry FOR YOU TO TALK 
S Swe 
A \ 


ABOUT THE WEDDING 
BY. \\ ARRANGEMENTS. 


MY FATHER |S 
WAITING? 


ALL RIGHT. T’LL 
GO RIGHT AWAY. 


ONCE UPON } il y 
Ln y | \ 


THERE WAS A TINY 


( COUNTRY CALLED THE } 
Y Jo 


KINGDOM OF KOD. JA 


ONE DAY, OUT OF AN 
ANCIENT BOOK ON 
DATABASES, 


FLEW A TINY 
LITTLE GIRL... 


DacaBases On ThE WEB 
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Databases are used for many different purposes, such as train seat reservation systems and 
bank deposit systems. They are indispensable in daily life and in business operations. As | 
showed Ruruna and Cain, web-based database systems are popular as well. In a web-based 
system, the communications protocol used is HyperText Transfer Protocol (HTTP). Server 
software running on a web server waits for a request from a user. When a user request 
(HTTP request) is sent, the software answers the request and returns a corresponding web 
page (HTTP response). 

A web page consists of text files in HTML format. Other files specified by Uniform 
Resource Locators (URLs) are embedded within a web page to present information such as 
images. 


WEB CLIENT WEB SERVER 


When a database is used with a web page, a database server is added to the system 
shown above. This system can be configured in three layers and is referred to as a three- 
tier client/server system. A three-tier client/server system consists of a presentation layer, a 
logic layer, and a data layer. 


LOGIC LAYER DATA LAYER 


DATABASE 
SERVER 


INTERNET 


PRESENTATION LAYER 


The presentation layer receives user input, such as search conditions, that needs to 
be passed on to the database. The presentation layer also processes query results received 
from the database so that they can be displayed. A web browser (such as Internet Explorer 
or Firefox) functions as a presentation tool for the user. 

The logic layer performs data processing. This layer is where SQL statements are 
composed. Processes performed here are written in one or more programming languages. 
Depending on the contents and load of processes, several servers, such as an application 
server and a web server, may be used to handle processing. 

The data layer processes data on a database server. Search results are returned from 
the database in response to SQL queries. 


Makes queries to Manages the 


the database and 


database 


processes data LOGIC LAYER DATA LAYER 


DATABASE 
SERVER 


SERVER 


INTERNET 


Receives user 
input and displays 


results 


PRESENTATION LAYER 


CLIENT 


The three-tier client/server configuration is a flexible and simple system. For example, 
when making additions or modifications to an application, you can separate the portion you 
want to edit as a logic layer. In the presentation layer, you can use a web browser, eliminat- 
ing the need for installing a separate software program. 
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Makes addition and 
modification of 


functions easier 
LOGIC LAYER DATA LAYER 


DATABASE 
SERVER 


SERVER 


INTERNET 


A web browser 
can be used here 
for operations 


PRESENTATION LAYER 


CLIENT 


USING STORED PROCEDURES 


In a web-based system, too much traffic on the network can be a problem. Fortunately, you 
can store program logic inside the database server itself as stored procedures. 

Storing procedures on the database server helps reduce the load on the network, 
because it eliminates the need for frequent transfers of SQL queries. In addition, storing 
procedures also makes it easier to develop applications, since standard processes can be 
encapsulated into easy-to-use procedures. Actually, stored procedures are just a special kind 
of a more broad category called stored programs. The other two types of stored programs 
are stored functions and triggers. 


TYPES OF STORED PROGRAMS 


Program Definition 

Stored procedure Program that does not return values from the processing procedure 
Stored function Program that returns values from the processing procedure 

Trigger Program that is launched automatically before and after the 


database operations 


QUESTIONS 


Can you answer these questions? The correct answers are on page 205. 


Qi 
In a three-tier client/server system, on which layer does the database operate? 


Q2 
In a three-tier client/server system, on which layer are user interactions received 
and results displayed? 


What /5 a DISTRIBUTED DataBase? 


In a Web-based system, processing is distributed among a database server, a web server, 
and a web browser, with different tasks assigned to each. This type of distributed system 
allows for flexible processing and decreases the processing capacity required by each server. 
But a database server itself can be distributed among several servers. Distributed 
database servers can be in different locations or on the same network. Note, however, 
that a distributed database may be handled as a single database. If the distributed data- 
base appears to be a single server, the user doesn’t have to worry about data locations or 
transfers. 
A database can be distributed horizontally or vertically, as you'll see. 


HORIZONTAL DISTRIBUTION 


Horizontal distribution uses several peer database servers. Each database server can use 
data from other database servers, and in turn, each one makes itself available to the other 
database servers. This structure is used for a system of extended databases that operate 
separately in each department. 

A horizontally distributed database is a failure-resistant system by design, since failure 
on one server will not affect database operation. 


SERVER A SERVER B 


Even when a failure 
occurs on the server 
in Department A, 


other servers 
continue to operate 


normally. 


SERVER C SERVER D 
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VERTICAL DISTRIBUTION 


Vertical distribution assigns different functions to different database servers. One of the 
servers functions as the main server and performs a key role, while the others are in charge 
of processing tasks as requested. A vertically distributed database makes it easier to man- 
age the main database server, though this main server will have a heavy load. An example 
of vertical distribution would include a company-wide main server and individual servers 
operating in each department. 


SERVER A 
This server 


operates the 
entire server 


system. 


SERVER B SERVER C 


PARTITIONING Data 


In a distributed database, data is spread across servers for storage. You should carefully 
consider how to divide up the data. Data can be split in the following ways. 


HORIZONTAL PARTITIONING 


A horizontal partition divides data into units of rows. Rows resulting from the split are dis- 
tributed across servers. This form of partitioning is often used when data can be ordered 
into groups in such a way that related data, which is often accessed at the same time, is 
stored on the same server. 


REGION A REGION B 
BUSINESS DEPARTMENT BUSINESS DEPARTMENT 


name price in charge 


Co 
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VERTICAL PARTITIONING 


A vertical partition divides data into units of columns. Columns resulting from the split are 
distributed across servers. For example, a vertical partition can be used to manage and join 
independent databases belonging to departments like the Merchandise Department, the 
Overseas Business Department, and the Export Department. 


MERCHANDISE Product | Unt’ | pana | Person OVERSEAS BUSINESS 
DEPARTMENT name price istrict Jin charge DEPARTMENT 


Databases on different servers in a distributed database system can be configured to act as 
a single database in the eyes of users. To achieve this, various steps must be taken to deal 
with the fact that data is actually distributed across different servers. 
First, whenever data is committed, all data on all servers must be updated consistently. 
In a distributed database system, the standard commit method may lead to one of 
the servers being updated while another is not, as shown below. This is a violation of the 
atomicity property of transactions, as this transaction will not end with either a commit or 
rollback. This would also cause the database system as a whole to become inconsistent. 


USER 


SERVER A SERVER B 


UPDATE 
OPERATION 


UPDATE 
OPERATION 


COMMIT 


Therefore, a two-phase commit is adopted in a distributed database system. The two- 
phase commit creates one commit operation from both the first and the second commit 
operations. 
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A two-phase commit operation involves a coordinator and participants. In the first 
phase of a two-phase commit operation, the coordinator asks the participants if a com- 
mit operation is possible. The participants send an OK reply if it is. This preparatory step is 
referred to as a prepare. In the second phase, the coordinator gives the instructions for a 
commit, and all participants perform a commit accordingly. 


COORDINATOR 


PARTICIPANT 


| 


PARTICIPANT 


Cc 


UPDATE 
OPERATION 
UPDATE 
OPERATION 
SECURE 
SECURE 
OK 
OK 
COMMIT 
COMMIT 


If any one node fails to secure the operation in the two-phase commit, all participants 
receive a rollback directive. This is how databases on all servers remain consistent with each 
other. 


COORDINATOR 


PARTICIPANT PARTICIPANT 


UPDATE 
OPERATION 
UPDATE 
OPERATION 
SECURE 
SECURE 
OK 
OK 
ROLLBACK 
ROLLBACK 
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QUESTIONS 
Try these questions about two-phase commits. The answers are on page 205. 
Q3 


In a two-phase commit scheme, what instructions does the coordinator give during 
the first phase? 


Q4 
In a two-phase commit scheme, what instructions does the coordinator give during 
the second phase? 


DacaBbasé REPLICATION 


Some distributed databases have a duplicated, or replica, database that reduces the load 
on the network. This practice is referred to as replication. The primary database is referred 
to as the master database, and the copy is called the replica. There are several types of 
replication. 


READ-ONLY 


A read-only replica is created and downloaded from the master database on the main 
server. To change data, users must connect to the main server. 


[] 


REPLICA REPLICA 


il 


MAIN SERVER 


[J 
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REPLICATION ENABLED FOR ALL SERVERS 


In this method, the same master database is shared by all servers. Updates to any of the 
servers are reflected in all other servers. 


Operations performed 
on this server are Operations performed 
reflected on all other on this server are 


servers. reflected on all other 
MAIN SERVER servers. 
SERVER A SERVER B 


CJ —— a 


Operations performed 


on this server are 
reflected on all other 
servers. 
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This final section introduces applied technologies related to databases. 


XML 


Extensible Markup Language (XML) is becoming increasingly popular as a data storage 
method. XML represents data by enclosing it in tags. Since these tags can convey informa- 
tion about the data they contain, this language is useful for data storage and retrieval. 

XML is useful because its strictly structured grammar makes programmed processes 
easy. Moreover, XML comes in text files (which are easy to edit) and can communicate with 
other systems. For these reasons, XML is sometimes used as a data representation method 
in place of a database. 


<?xml version="1.0"?> 
<products> 
<fruit> 
<product code>101</product code> 
<product name>Melon</product name> 
<unit price>800</unit price> 
</fruit> 
<fruit> 
<product code>102</product code> 
<product name>Strawberry</product name> 
<unit price>150</unit price> 
</fruit> 
<fruit> 
<product code>103</product code> 
<product name>Apple</product name> 
<unit price>120</unit price> 
</fruit> 
</products> 


OBJECT-ORIENTED DATABASES 


A relational database stores text data in a table. However, a relational database may be 
inadequate when handling certain types of data. That’s where an object-oriented database 
(OODB) comes in. 

The object-oriented method uses objects—sets of data and instructions on how that 
data should be used. You can hide the data and only expose the operations upon the data 
in order to handle the object as an independent component. This technique is referred to as 
encapsulation. 

In an object-oriented database, each object is represented with an identifier. Some- 
times, an object is also called an instance. 

In an object-oriented database, you can also manage compound objects—one object 
nested within another. This means, for example, that you can store data consisting of an 
image combined with text as a single object. The object-oriented database allows for flexible 
management of complex data. 


é RURUNA KOD 
OBJECT-ORIENTED , THE KINGDOM OF KOD 
DATAB, ==>] 


ASE . PRINCESS 
PROFILE 
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In an object-oriented database, various concepts can ease object-oriented develop- 
ment. The template for objects is referred to as class. For example, suppose you have 
designed an Apple class. Objects (instances) in that class may be Apple A, Apple B, and so on. 
The Apple class enables the creation of these objects. 


ote 
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In an object-oriented scheme, a class can also have hierarchical relationships. You can 
create a child class that has the same data and functions of a parent class. This relationship 
is referred to as inheritance. You can also give unique functions to the child class. 

For example, class Apple and class Orange may inherit the data and functions from 
class Fruit, but they also each have their own unique data and functions. In an object- 
oriented scheme, you can use hierarchical relationships to allow for efficient development. 


FRUIT 


. 


SUMMARY 


ANSWERS 


Qi 
Q2 
Q3 
Q4 


The three-tier client/server system is a method of Web-based system configuration. 
A database acts as a data layer. 

A distributed database system handles databases that are dispersed. 

A two-phase commit method is used in a distributed database. 


Data layer 
Presentation layer 
Prepare 


Commit or rollback 


CLOSING REMARKS 


Have you enjoyed studying databases? You will need to learn even more before you can 
manage all the aspects of operating a database, but the fundamentals of databases always 
stay the same. By firmly understanding the basics, you can identify significant data in the 
real world and design and operate databases. You can acquire advanced database skills by 
building on your fundamental knowledge. Good luck! 
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FREQUENTLY YSED SQL 
STATEMENTS 


BASIC QUERY 


SELECT column_name, ... 
FROM table name; 


CONDITIONAL QUERY 


SELECT column_name, ... 
FROM table name 
WHERE condition; 


PATTERN MATCHING 


SELECT column_name, ... 
FROM table name 
WHERE column_name LIKE 'pattern'; 


SORTED SEARCH 


SELECT column_name, ... 
FROM table name 

WHERE condition 

ORDER BY column_name; 


AGGREGATING AND GROUPING 


SELECT column_name, ... 

FROM table name 

WHERE condition 

GROUP BY column_names_for_grouping 
HAVING condition_for_grouped_rows 


JOINING TABLES 


SELECT table _name1.column_name, ... 
FROM table name1,table name2, ... 
WHERE table _namei.column_name = table_name2.column_name 


CREATING A TABLE 


CREATE TABLE table name( 
column_name1 datatype, 
column_name2 datatype, 


Ve 
CREATING A VIEW 


CREATE VIEW view_name 
AS SELECT statement 


DELETING A REAL TABLE 


DROP TABLE table name; 


DELETING A VIEW 


DROP VIEW view_name; 


INSERTING A ROW 


INSERT INTO table name(column_name1, ... 


VALUES (value1, ...) 


UPDATING A ROW 
UPDATE table_name 


SET column_name = valuei, ... 
WHERE condition; 


DELETING A ROW 


DELETE FROM table name 
WHERE condition; 
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access rights, 19, 106, 126-129, 
141-142, 159-160, 167 

actual condition, 52, 55-56, 59, 74 

aggregate functions, 98-100, 110-111 

ALL statements, 159 

application servers, 182, 195 

atomicity, 153-154 

authorized users, 141, 159 

AVG (average) function, 98, 99, 110 


B 


backup copies, 161 
base tables, 160 
B-tree indexing, 163 
buffers, 161 
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cardinality, 74 
Cartesian product operations, 37, 39, 42 
character strings, 84, 108 
checkpoints, 161-162 
coarse granularity, 157 
columns, 34, 84 
COMMIT statements, 133, 137, 150, 
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comparison operators, 107 
compound objects, 203 
conceptual schema, 81 
concurrency controls 

isolation levels, 158 

lock-based controls, 131-137, 
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correlated subqueries, 113-114 
corrupted data, 20, 154 
cost-based processing, 167 
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CREATE TABLE statements, 103, 
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CREATE VIEW statements, 117 
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Data Control Language (DCL), 106 
Data Definition Language (DDL), 106 
data extraction operations, 36-37, 39-47 
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Data Manipulation Language (DML), 106 
data models, 32-39 
data processing, 35-37, 47-48, 130, 159, 
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data recovery, 20, 147-152, 161-164, 
167 
data security, 19, 127, 138-142, 
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182, 184 
data tags, 202 
database design, 19, 26 

determining data conditions, 74 


E-R (entity-relationship) model, 50-55, 


74-77, 81 
normalization, 60-72, 78-81 
steps for, 81, 84 
database failures, 161 
database management system 
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database replication, 201-202 
database terms, 26-31 
databases 
building from existing systems, 14 
defined, 6, 10, 15, 187 
efficiency of, 3-4, 15, 19, 146, 174 
types of, 32-39 
use of, 19-21, 175-182 
DBMS (database management system), 21 
DCL (Data Control Language), 106 
DDL (Data Definition Language), 106 
deadlocks, 136, 158 
DELETE statements, 104, 116, 118, 
119, 159 
difference operations, 37, 39, 41 
dirty read, 158 
disaster recovery, 20, 147-150, 
161-164, 167 
disk access count, 145 
distributed database systems 
horizontal distribution, 197 
overview of, 183-184, 197-199, 205 
partitioning data, 198-199 
replication in, 201-202 


two-phase commit operations in, 
199-201, 205 
vertical distribution, 198 
dividing tables. See normalization 
division operations, 37, 43, 45 
DML (Data Manipulation Language), 106 
DROP TABLE/DROP VIEW 
statements, 118 
duplicated data, 11, 16, 18, 19, 21, 29 
durability, 153, 159-160 
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encapsulation, 203 

entities, 52-54, 74 

entity-relationship (E-R) model, 50-55, 
74-77, 81 

exclusive locks, 134-136, 155-156 

Extensible Markup Language (XML), 202 

external schema, 81 

extraction operations, data, 36-37, 39-47 
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ailure-resistant systems, 184, 197 
ailures, database, 161 

ields, 27-28, 30, 34, 35, 48 
ile-based systems, 3, 10, 16, 21, 32 
ine granularity, 157 

irst normal forms, 62-64, 66, 78-79 
oreign keys, 44, 48, 72, 101 

orms, 62-70, 81-82 

ull-match searching, 163 
unctionally dependent values, 79 
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GRANT statements, 159, 168 
granularity, 157 

GROUP BY phrase, 110 
grouping, 110, 159 
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hash function, 167 

hash indexing, 163 

HAVING phrase, 111 

hierarchical data model, 32, 33, 39, 204 

horizontal distribution, 197 

horizontal partition, 198 

HyperText Markup Language (HTML), 194 

Hypertext Transfer Protocol (HTTP), 178, 
180, 194 
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inconsistent data, 153, 154, 159, 
199-201 

independent data management, 19, 72 

indexes/indexing, 143-147, 162-164, 
167 

inner join, 115 

inputting data, 21, 90-92, 103-104, 
106, 116 

NSERT statements, 104, 116, 119, 159 

instances, 203 

internal schema, 81 

nternational Organization for Standard- 
ization (ISO), 124 

nternational Standard Book Number 
(ISBN), 45 

nternet databases. See Web-based 
database systems 

intersection operations, 37, 39, 41 

SBN (International Standard Book 
Number), 45 

SO (International Organization for 
Standardization), 124 

isolation, 153, 155-158 

isolation levels, 158 
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Japanese Industrial Standards (JIS), 124 
join operations, 37, 43, 44, 48, 165 
joining tables, 44, 101-102, 114-115 


K 
keys 
foreign, 44, 48, 72, 101 
primary, 35, 44, 48, 65, 67, 72, 
78-79, 101, 103, 115 
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LIKE statements, 97, 108 

ocking granularity, 157 

ocks/lock-based controls, 131-137, 
155-157, 167, 175-176, 182 

ogic layer, 194-196 

ogical operators, 107 

ogs, 148-149 

ost data, 20, 154 
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many-to-many relationships, 55, 74, 
75, 81 

master databases, 201-202 

mathematical operations. See operations 
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MAX (maximum value) function, 99-100, 
110 

media failures, 161 

memory. See stored procedures 

MIN (minimum value) function, 99, 110 


N 


nested loop method, 165 
network data model, 33, 39 
non-repeatable read, 158 
normalization, 60-72, 78-81 
normalized tables, 72, 91 
null, 30, 108 
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object-oriented databases (OODB), 
203-205 
one-to-many relationships, 55, 75, 81 
one-to-one relationships, 74, 81 
OODB (object-oriented databases), 
203-205 
operations 
Cartesian product, 37, 39, 42 
data extraction, 39-47 
difference, 37, 39, 41 
division, 37, 43, 45 
intersection, 37, 39, 41 
join, 37, 43, 44, 48, 165 
projection, 36, 37, 43, 165 
relational, 43-47 
selection, 37, 39, 43, 47, 48, 165 
set, 39-42 
union, 37, 39, 40, 48 
operators, 107 
optimistic controls, 158 
optimization, query, 164-167 
optimizers, 167 
ORDER BY statements, 98 
outer join, 115 
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partitioning data, 198-199 
passwords, 141 
pattern matching, 108 
permissions, 19, 141-142, 159-160, 167 
phantom read, 158 
presentation layers, 205 
primary keys, 35, 44, 48, 65, 67, 72, 
78-79, 79, 101, 103, 115 
problems, data management 
conflicting data, 13, 17-18, 21, 60, 71, 
116, 153, 158 
corrupted/lost data, 20, 154 


database failures, 161 
difficulty changing data, 13, 14, 17, 18 
duplicated data, 11, 16, 18, 19, 21, 29 
inconsistent data, 153, 154, 159, 
199-201 

shared data, 12, 20, 21,129,175 
processing data, 35-37, 47-48, 130, 159, 
167, 182, 195-198 
programming languages, 178, 180, 
194, 202 
projection operations, 36, 37, 43, 165 
protecting data, 19, 127, 138-142, 
159-160, 161-164, 167, 176, 
182, 184 
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queries. See SQL; SQL statements 
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